114 lines
3.9 KiB
ActionScript
114 lines
3.9 KiB
ActionScript
|
/*
|
||
|
Copyright (c) 2008, Adobe Systems Incorporated
|
||
|
All rights reserved.
|
||
|
|
||
|
Redistribution and use in source and binary forms, with or without
|
||
|
modification, are permitted provided that the following conditions are
|
||
|
met:
|
||
|
|
||
|
* Redistributions of source code must retain the above copyright notice,
|
||
|
this list of conditions and the following disclaimer.
|
||
|
|
||
|
* Redistributions in binary form must reproduce the above copyright
|
||
|
notice, this list of conditions and the following disclaimer in the
|
||
|
documentation and/or other materials provided with the distribution.
|
||
|
|
||
|
* Neither the name of Adobe Systems Incorporated nor the names of its
|
||
|
contributors may be used to endorse or promote products derived from
|
||
|
this software without specific prior written permission.
|
||
|
|
||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
|
||
|
IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
|
||
|
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||
|
PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||
|
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||
|
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||
|
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||
|
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||
|
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||
|
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
|
*/
|
||
|
|
||
|
package com.adobe.crypto
|
||
|
{
|
||
|
import mx.formatters.DateFormatter;
|
||
|
import mx.utils.Base64Encoder;
|
||
|
|
||
|
/**
|
||
|
* Web Services Security Username Token
|
||
|
*
|
||
|
* Implementation based on algorithm description at
|
||
|
* http://www.oasis-open.org/committees/wss/documents/WSS-Username-02-0223-merged.pdf
|
||
|
*/
|
||
|
public class WSSEUsernameToken
|
||
|
{
|
||
|
/**
|
||
|
* Generates a WSSE Username Token.
|
||
|
*
|
||
|
* @param username The username
|
||
|
* @param password The password
|
||
|
* @param nonce A cryptographically random nonce (if null, the nonce
|
||
|
* will be generated)
|
||
|
* @param timestamp The time at which the token is generated (if null,
|
||
|
* the time will be set to the moment of execution)
|
||
|
* @return The generated token
|
||
|
* @langversion ActionScript 3.0
|
||
|
* @playerversion Flash 9.0
|
||
|
* @tiptext
|
||
|
*/
|
||
|
public static function getUsernameToken(username:String, password:String, nonce:String=null, timestamp:Date=null):String
|
||
|
{
|
||
|
if (nonce == null)
|
||
|
{
|
||
|
nonce = generateNonce();
|
||
|
}
|
||
|
nonce = base64Encode(nonce);
|
||
|
|
||
|
var created:String = generateTimestamp(timestamp);
|
||
|
|
||
|
var password64:String = getBase64Digest(nonce,
|
||
|
created,
|
||
|
password);
|
||
|
|
||
|
var token:String = new String("UsernameToken Username=\"");
|
||
|
token += username + "\", " +
|
||
|
"PasswordDigest=\"" + password64 + "\", " +
|
||
|
"Nonce=\"" + nonce + "\", " +
|
||
|
"Created=\"" + created + "\"";
|
||
|
return token;
|
||
|
}
|
||
|
|
||
|
private static function generateNonce():String
|
||
|
{
|
||
|
// Math.random returns a Number between 0 and 1. We don't want our
|
||
|
// nonce to contain invalid characters (e.g. the period) so we
|
||
|
// strip them out before returning the result.
|
||
|
var s:String = Math.random().toString();
|
||
|
return s.replace(".", "");
|
||
|
}
|
||
|
|
||
|
internal static function base64Encode(s:String):String
|
||
|
{
|
||
|
var encoder:Base64Encoder = new Base64Encoder();
|
||
|
encoder.encode(s);
|
||
|
return encoder.flush();
|
||
|
}
|
||
|
|
||
|
internal static function generateTimestamp(timestamp:Date):String
|
||
|
{
|
||
|
if (timestamp == null)
|
||
|
{
|
||
|
timestamp = new Date();
|
||
|
}
|
||
|
var dateFormatter:DateFormatter = new DateFormatter();
|
||
|
dateFormatter.formatString = "YYYY-MM-DDTJJ:NN:SS"
|
||
|
return dateFormatter.format(timestamp) + "Z";
|
||
|
}
|
||
|
|
||
|
internal static function getBase64Digest(nonce:String, created:String, password:String):String
|
||
|
{
|
||
|
return SHA1.hashToBase64(nonce + created + password);
|
||
|
}
|
||
|
}
|
||
|
}
|