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

org.openid4java.message.ax.StoreRequest Maven / Gradle / Ivy

There is a newer version: 1.0.0.0
Show newest version
/*
 * Copyright 2006-2008 Sxip Identity Corporation
 */

package org.openid4java.message.ax;

import org.openid4java.message.MessageException;
import org.openid4java.message.Parameter;
import org.openid4java.message.ParameterList;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

/**
 * Implements the extension for Attribute Exchange store requests.
 *
 * @author Marius Scurtescu, Johnny Bufu
 */
public class StoreRequest extends AxPayload
{
    private static Log _log = LogFactory.getLog(StoreRequest.class);
    private static final boolean DEBUG = _log.isDebugEnabled();

    /**
     * Constructs a Store Request with an empty parameter list.
     */
    protected StoreRequest()
    {
        _parameters.set(new Parameter("mode", "store_request"));

        if (DEBUG) _log.debug("Created empty store request.");
    }

    /**
     * Constructs a Store Request with an empty parameter list.
     */
    public static StoreRequest createStoreRequest()
    {
        return new StoreRequest();
    }

    /**
     * Constructs a StoreRequest from a parameter list.
     * 

* The parameter list can be extracted from a received message with the * getExtensionParams method of the Message class, and MUST NOT contain * the "openid.." prefix. */ protected StoreRequest(ParameterList params) { _parameters = params; } /** * Constructs a StoreRequest from a parameter list. *

* The parameter list can be extracted from a received message with the * getExtensionParams method of the Message class, and MUST NOT contain * the "openid.." prefix. */ public static StoreRequest createStoreRequest(ParameterList params) throws MessageException { StoreRequest req = new StoreRequest(params); if (! req.isValid()) throw new MessageException("Invalid parameters for a store request"); if (DEBUG) _log.debug("Created store request from parameter list:\n" + params); return req; } /** * Checks the validity of the extension. *

* Used when constructing a extension from a parameter list. * * @return True if the extension is valid, false otherwise. */ public boolean isValid() { if ( ! _parameters.hasParameter("mode") || ! "store_request".equals(_parameters.getParameterValue("mode"))) { _log.warn("Invalid mode value in store_request: " + _parameters.getParameterValue("mode")); return false; } return super.isValid(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy