usr/src/lib/libslp/javalib/com/sun/slp/SSrvReg.java
author Mark J. Nelson <Mark.J.Nelson@Sun.COM>
Wed, 06 Aug 2008 16:29:39 -0600
changeset 7298 b69e27387f74
parent 0 68f95e015346
permissions -rw-r--r--
6733918 Teamware has retired, please welcome your new manager, Mercurial 4758439 some files use "current date" sccs keywords 6560843 asm sources should not rely on .file "%M%" for naming STT_FILE symbols 6560958 Solaris:: perl modules should not use SCCS keywords in version information 6729074 webrev doesn't deal well with remote ssh hg parents

/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License (the "License").
 * You may not use this file except in compliance with the License.
 *
 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 * or http://www.opensolaris.org/os/licensing.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 * If applicable, add the following below this CDDL HEADER, with the
 * fields enclosed by brackets "[]" replaced with your own identifying
 * information: Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
 */
/*
 * Copyright (c) 1999, 2001 by Sun Microsystems, Inc.
 * All rights reserved.
 *
 */

//  SSrvReg.java:      Message class for SLP service registration request.
//  Author:           James Kempf
//  Created On:       Thu Oct  9 14:47:48 1997
//  Last Modified By: Jason Goldschmidt
//  Last Modified On: Thu Apr  5 14:46:29 2001
//  Update Count:     107
//

package com.sun.slp;

import java.util.*;
import java.io.*;


/**
 * The SSrvReg class models the server side SLP service registration. The
 * default class does SLPv2 regs, but subclasses can do other versions
 * by redefining the initialize() and makeReply() messages.
 *
 * @author James Kempf
 */

class SSrvReg extends SrvLocMsgImpl {

    ServiceURL URL = null;	         // the service URL.
    String serviceType = "";	         // service type.
    Vector attrList = new Vector();        // ServiceLocationAttribute objects.
    Hashtable URLSignature = null;  // signature for URL.
    Hashtable attrSignature = null; // the signatures for the attributes.

    // Construct a SSrvReg from the input stream.

    SSrvReg(SrvLocHeader hdr, DataInputStream dis)
	throws ServiceLocationException, IOException {

	super(hdr, SrvLocHeader.SrvReg);

	this.initialize(dis);

    }

    // Initialize the object from the input stream.

    void initialize(DataInputStream dis)
	throws ServiceLocationException, IOException {

	SLPServerHeaderV2 hdr = (SLPServerHeaderV2)getHeader();
	StringBuffer buf = new StringBuffer();

	// Parse in the service URL

	Hashtable table = new Hashtable();

	URL =
	    hdr.parseServiceURLIn(dis,
				  table,
				ServiceLocationException.INVALID_REGISTRATION);

	URLSignature = (Hashtable)table.get(URL);

	// Parse in service type name.

	hdr.getString(buf, dis);

	// Validate and set URL type.

	ServiceType t = new ServiceType(buf.toString());

	if (!(URL.getServiceType()).isServiceURL() &&
	    !t.equals(URL.getServiceType())) {
	    URL.setServiceType(t);

	}

	// Parse in the scope list.

	hdr.parseScopesIn(dis);

	// Parse in the attribute list.

	attrSignature =
	    hdr.parseAuthenticatedAttributeVectorIn(attrList, dis, false);

	hdr.constructDescription("SrvReg",
				 "       URL=``" +
				 URL + "''\n" +
				 "       service type=``" +
				 serviceType + "''\n" +
				 "       attribute list=``" +
				 attrList + "''\n" +
				 "       URL signature=" +
				 AuthBlock.desc(URLSignature) + "\n" +
				 "       attribute signature=" +
				 AuthBlock.desc(attrSignature) + "\n");
    }

    // Return a SrvAck. We ignore the existing flag, since in V2, fresh comes
    //  in. In this case, all we need to do is clone the header.

    SrvLocMsg makeReply(boolean existing) {

	SLPServerHeaderV2 hdr =
	    ((SLPServerHeaderV2)getHeader()).makeReplyHeader();

	// Construct description.

	hdr.constructDescription("SrvAck", "");

	return hdr;

    }
}