root/usr/src/lib/libslp/javalib/com/sun/slp/SSrvReg.java
/*
 * 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;

    }
}