1069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project/*
2069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * $HeadURL: http://svn.apache.org/repos/asf/httpcomponents/httpclient/trunk/module-client/src/main/java/org/apache/http/impl/auth/NTLMEngine.java $
3069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * $Revision: 659788 $
4069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * $Date: 2008-05-24 03:42:23 -0700 (Sat, 24 May 2008) $
5069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
6069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * ====================================================================
7069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
8069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  Licensed to the Apache Software Foundation (ASF) under one or more
9069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  contributor license agreements.  See the NOTICE file distributed with
10069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  this work for additional information regarding copyright ownership.
11069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  The ASF licenses this file to You under the Apache License, Version 2.0
12069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  (the "License"); you may not use this file except in compliance with
13069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  the License.  You may obtain a copy of the License at
14069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
15069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
16069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
17069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  Unless required by applicable law or agreed to in writing, software
18069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  distributed under the License is distributed on an "AS IS" BASIS,
19069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  See the License for the specific language governing permissions and
21069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *  limitations under the License.
22069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * ====================================================================
23069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
24069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * This software consists of voluntary contributions made by many
25069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * individuals on behalf of the Apache Software Foundation.  For more
26069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * information on the Apache Software Foundation, please see
27069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <http://www.apache.org/>.
28069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
29069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project */
30069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
31069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectpackage org.apache.http.impl.auth;
32069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
33069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project/**
34069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * Abstract NTLM authentication engine. The engine can be used to
35069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * generate Type1 messages and Type3 messages in response to a
36069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * Type2 challenge.
37069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * <p/>
38069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * For details see <a href="http://davenport.sourceforge.net/ntlm.html">this resource</a>
39069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project *
40069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project * @author <a href="mailto:oleg at ural.ru">Oleg Kalnichevski</a>
41d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath *
42d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath * @deprecated Please use {@link java.net.URL#openConnection} instead.
43d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath *     Please visit <a href="http://android-developers.blogspot.com/2011/09/androids-http-clients.html">this webpage</a>
44d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath *     for further details.
45069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project*/
46d42abb2fd917184764daf22f5f299e848b8701d7Narayan Kamath@Deprecated
47069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Projectpublic interface NTLMEngine {
48069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
49069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    /**
50069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * Generates a Type1 message given the domain and workstation.
51069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     *
52069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @param domain Optional Windows domain name. Can be <code>null</code>.
53069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @param workstation Optional Windows workstation name. Can be
54069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     *  <code>null</code>.
55069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @return Type1 message
56069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @throws NTLMEngineException
57069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     */
58069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    String generateType1Msg(
59069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            String domain,
60069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            String workstation) throws NTLMEngineException;
61069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
62069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    /**
63069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * Generates a Type3 message given the user credentials and the
64069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * authentication challenge.
65069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     *
66069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @param username Windows user name
67069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @param password Password
68069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @param domain Windows domain name
69069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @param workstation Windows workstation name
70069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @param challenge Type2 challenge.
71069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @return Type3 response.
72069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     * @throws NTLMEngineException
73069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project     */
74069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project    String generateType3Msg(
75069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            String username,
76069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            String password,
77069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            String domain,
78069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            String workstation,
79069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project            String challenge) throws NTLMEngineException;
80069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project
81069490a5ca2fd1988d29daf45d892f47ad665115The Android Open Source Project}
82