office-gobmx/ucbhelper/source/provider/simpleauthenticationrequest.cxx
Noel Grandin 185ed3ddb8 teach loplugin:constantparam about simple constructor calls
Change-Id: I7d2a28ab5951fbdb5a427c84e9ac4c1e32ecf9f9
Reviewed-on: https://gerrit.libreoffice.org/37280
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
2017-05-08 08:29:03 +02:00

155 lines
5.6 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
#include <com/sun/star/task/XMasterPasswordHandling.hpp>
#include <com/sun/star/ucb/URLAuthenticationRequest.hpp>
#include <ucbhelper/simpleauthenticationrequest.hxx>
using namespace com::sun::star;
using namespace ucbhelper;
SimpleAuthenticationRequest::SimpleAuthenticationRequest(
const OUString & rURL,
const OUString & rServerName,
const OUString & rRealm,
const OUString & rUserName,
const OUString & rPassword,
bool bAllowUseSystemCredentials,
bool bAllowSessionStoring )
{
// Fill request...
ucb::URLAuthenticationRequest aRequest;
// aRequest.Message = // OUString
// aRequest.Context = // XInterface
aRequest.Classification = task::InteractionClassification_ERROR;
aRequest.ServerName = rServerName;
// aRequest.Diagnostic = // OUString
aRequest.HasRealm = !rRealm.isEmpty();
if ( aRequest.HasRealm )
aRequest.Realm = rRealm;
aRequest.HasUserName = true;
aRequest.UserName = rUserName;
aRequest.HasPassword = true;
aRequest.Password = rPassword;
aRequest.HasAccount = false;
aRequest.URL = rURL;
initialize(aRequest,
false,
true,
true,
aRequest.HasAccount,
bAllowUseSystemCredentials,
bAllowSessionStoring );
}
SimpleAuthenticationRequest::SimpleAuthenticationRequest(
const OUString & rURL,
const OUString & rServerName,
EntityType eRealmType,
const OUString & rRealm,
EntityType eUserNameType,
const OUString & rUserName,
EntityType ePasswordType,
const OUString & rPassword)
{
// Fill request...
ucb::URLAuthenticationRequest aRequest;
// aRequest.Message = // OUString
// aRequest.Context = // XInterface
aRequest.Classification = task::InteractionClassification_ERROR;
aRequest.ServerName = rServerName;
// aRequest.Diagnostic = // OUString
aRequest.HasRealm = eRealmType != ENTITY_NA;
if ( aRequest.HasRealm )
aRequest.Realm = rRealm;
aRequest.HasUserName = eUserNameType != ENTITY_NA;
if ( aRequest.HasUserName )
aRequest.UserName = rUserName;
aRequest.HasPassword = ePasswordType != ENTITY_NA;
if ( aRequest.HasPassword )
aRequest.Password = rPassword;
aRequest.HasAccount = false;
aRequest.URL = rURL;
initialize(aRequest,
eRealmType == ENTITY_MODIFY,
eUserNameType == ENTITY_MODIFY,
ePasswordType == ENTITY_MODIFY,
false,
false,
true );
}
void SimpleAuthenticationRequest::initialize(
const ucb::URLAuthenticationRequest & rRequest,
bool bCanSetRealm,
bool bCanSetUserName,
bool bCanSetPassword,
bool bCanSetAccount,
bool bAllowUseSystemCredentials,
bool bAllowSessionStoring )
{
setRequest( uno::makeAny( rRequest ) );
// Fill continuations...
unsigned int nSize = 1;
unsigned int nPos = 0;
if( bAllowSessionStoring )
nSize++;
nSize++;
uno::Sequence< ucb::RememberAuthentication > aRememberModes( nSize );
aRememberModes[ nPos++ ] = ucb::RememberAuthentication_NO;
if( bAllowSessionStoring )
aRememberModes[ nPos++ ] = ucb::RememberAuthentication_SESSION;
aRememberModes[ nPos++ ] = ucb::RememberAuthentication_PERSISTENT;
m_xAuthSupplier
= new InteractionSupplyAuthentication(
this,
bCanSetRealm,
bCanSetUserName,
bCanSetPassword,
bCanSetAccount,
aRememberModes, // rRememberPasswordModes
ucb::RememberAuthentication_SESSION, // eDefaultRememberPasswordMode
aRememberModes, // rRememberAccountModes
ucb::RememberAuthentication_SESSION, // eDefaultRememberAccountMode
bAllowUseSystemCredentials // bCanUseSystemCredentials,
);
uno::Sequence<
uno::Reference< task::XInteractionContinuation > > aContinuations( 3 );
aContinuations[ 0 ] = new InteractionAbort( this );
aContinuations[ 1 ] = new InteractionRetry( this );
aContinuations[ 2 ] = m_xAuthSupplier.get();
setContinuations( aContinuations );
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */