[Libreoffice-commits] core.git: basic/source

Stephan Bergmann sbergman at redhat.com
Tue Mar 8 14:07:04 UTC 2016


 basic/source/inc/runtime.hxx     |    7 --
 basic/source/runtime/iosys.cxx   |   97 ---------------------------------------
 basic/source/runtime/methods.cxx |   49 -------------------
 basic/source/runtime/runtime.cxx |    7 --
 4 files changed, 160 deletions(-)

New commits:
commit 29cb1f192312d395067b5024e40aea3388f7674d
Author: Stephan Bergmann <sbergman at redhat.com>
Date:   Tue Mar 8 15:04:58 2016 +0100

    Remove ancient StarPortal leftovers
    
    No UNO bridge has a "user" token in its description anyway, so
    needsSecurityRestrictions always returned false.
    
    Change-Id: Ibc3aa25212a2e8b245c13578fa29582be42791e6

diff --git a/basic/source/inc/runtime.hxx b/basic/source/inc/runtime.hxx
index aef620b..94e2aeb 100644
--- a/basic/source/inc/runtime.hxx
+++ b/basic/source/inc/runtime.hxx
@@ -435,13 +435,6 @@ inline void checkArithmeticOverflow( SbxVariable* pVar )
 
 StarBASIC* GetCurrentBasic( StarBASIC* pRTBasic );
 
-// Get information if security restrictions should be
-// used (File IO based on UCB, no RTL function SHELL
-// no DDE functionality, no DLLCALL) in basic because
-// of portal "virtual" users (portal user != UNIX user)
-// (Implemented in iosys.cxx)
-bool needSecurityRestrictions();
-
 // Returns true if UNO is available, otherwise the old
 // file system implementation has to be used
 // (Implemented in iosys.cxx)
diff --git a/basic/source/runtime/iosys.cxx b/basic/source/runtime/iosys.cxx
index 46c90be..8e72688 100644
--- a/basic/source/runtime/iosys.cxx
+++ b/basic/source/runtime/iosys.cxx
@@ -23,7 +23,6 @@
 #include <vcl/button.hxx>
 #include <vcl/msgbox.hxx>
 #include <vcl/svapp.hxx>
-#include <osl/security.h>
 #include <osl/file.hxx>
 #include <tools/urlobj.hxx>
 #include <osl/mutex.hxx>
@@ -175,102 +174,6 @@ void SbiStream::MapError()
     }
 }
 
-// TODO: Code is copied from daemons2/source/uno/asciiEncoder.cxx
-
-OUString findUserInDescription( const OUString& aDescription )
-{
-    OUString user;
-
-    sal_Int32 index;
-    sal_Int32 lastIndex = 0;
-
-    do
-    {
-        index = aDescription.indexOf((sal_Unicode) ',', lastIndex);
-        OUString token = (index == -1) ? aDescription.copy(lastIndex) : aDescription.copy(lastIndex, index - lastIndex);
-
-        lastIndex = index + 1;
-
-        sal_Int32 eindex = token.indexOf((sal_Unicode)'=');
-        OUString left = token.copy(0, eindex).toAsciiLowerCase().trim();
-        OUString right = INetURLObject::decode( token.copy(eindex + 1).trim(),
-                            INetURLObject::DECODE_WITH_CHARSET );
-
-        if( left == "user" )
-        {
-            user = right;
-            break;
-        }
-    }
-    while(index != -1);
-
-    return user;
-}
-
-bool needSecurityRestrictions()
-{
-    static bool bNeedInit = true;
-    static bool bRetVal = true;
-
-    if( bNeedInit )
-    {
-        bNeedInit = false;
-
-        // Get system user to compare to portal user
-        oslSecurity aSecurity = osl_getCurrentSecurity();
-        OUString aSystemUser;
-        bool bRet = osl_getUserName( aSecurity, &aSystemUser.pData );
-        osl_freeSecurityHandle(aSecurity);
-        if( !bRet )
-        {
-            // No valid security! -> Secure mode!
-            return true;
-        }
-
-        Reference< XComponentContext > xContext = comphelper::getProcessComponentContext();
-        Reference< XBridgeFactory2 > xBridgeFac( BridgeFactory::create(xContext) );
-
-        Sequence< Reference< XBridge > > aBridgeSeq = xBridgeFac->getExistingBridges();
-        sal_Int32 nBridgeCount = aBridgeSeq.getLength();
-
-        if( nBridgeCount == 0 )
-        {
-            // No bridges -> local
-            bRetVal = false;
-            return bRetVal;
-        }
-
-        // Iterate through all bridges to find (portal) user property
-        const Reference< XBridge >* pBridges = aBridgeSeq.getConstArray();
-        bRetVal = false;    // Now only sal_True if user different from portal user is found
-        sal_Int32 i;
-        for( i = 0 ; i < nBridgeCount ; i++ )
-        {
-            const Reference< XBridge >& rxBridge = pBridges[ i ];
-            OUString aDescription = rxBridge->getDescription();
-            OUString aPortalUser = findUserInDescription( aDescription );
-            if( !aPortalUser.isEmpty() )
-            {
-                // User Found, compare to system user
-                if( aPortalUser == aSystemUser )
-                {
-                    // Same user -> system security is ok, bRetVal stays FALSE
-                    break;
-                }
-                else
-                {
-                    // Different user -> Secure mode!
-                    bRetVal = true;
-                    break;
-                }
-            }
-        }
-        // No user found or PortalUser != SystemUser -> Secure mode! (Keep default value)
-    }
-
-    return bRetVal;
-}
-
 // Returns sal_True if UNO is available, otherwise the old file
 // system implementation has to be used
 // #89378 New semantic: Don't just ask for UNO but for UCB
diff --git a/basic/source/runtime/methods.cxx b/basic/source/runtime/methods.cxx
index 97e1eca..6e83e1c 100644
--- a/basic/source/runtime/methods.cxx
+++ b/basic/source/runtime/methods.cxx
@@ -3602,13 +3602,6 @@ RTLFUNC(Shell)
     (void)pBasic;
     (void)bWrite;
 
-    // No shell command for "virtual" portal users
-    if( needSecurityRestrictions() )
-    {
-        StarBASIC::Error(ERRCODE_BASIC_NOT_IMPLEMENTED);
-        return;
-    }
-
     sal_Size nArgCount = rPar.Count();
     if ( nArgCount < 2 || nArgCount > 5 )
     {
@@ -3964,13 +3957,6 @@ RTLFUNC(DDEInitiate)
     (void)pBasic;
     (void)bWrite;
 
-    // No DDE for "virtual" portal users
-    if( needSecurityRestrictions() )
-    {
-        StarBASIC::Error(ERRCODE_BASIC_NOT_IMPLEMENTED);
-        return;
-    }
-
     int nArgs = (int)rPar.Count();
     if ( nArgs != 3 )
     {
@@ -3998,13 +3984,6 @@ RTLFUNC(DDETerminate)
     (void)pBasic;
     (void)bWrite;
 
-    // No DDE for "virtual" portal users
-    if( needSecurityRestrictions() )
-    {
-        StarBASIC::Error(ERRCODE_BASIC_NOT_IMPLEMENTED);
-        return;
-    }
-
     rPar.Get(0)->PutEmpty();
     int nArgs = (int)rPar.Count();
     if ( nArgs != 2 )
@@ -4026,13 +4005,6 @@ RTLFUNC(DDETerminateAll)
     (void)pBasic;
     (void)bWrite;
 
-    // No DDE for "virtual" portal users
-    if( needSecurityRestrictions() )
-    {
-        StarBASIC::Error(ERRCODE_BASIC_NOT_IMPLEMENTED);
-        return;
-    }
-
     rPar.Get(0)->PutEmpty();
     int nArgs = (int)rPar.Count();
     if ( nArgs != 1 )
@@ -4054,13 +4026,6 @@ RTLFUNC(DDERequest)
     (void)pBasic;
     (void)bWrite;
 
-    // No DDE for "virtual" portal users
-    if( needSecurityRestrictions() )
-    {
-        StarBASIC::Error(ERRCODE_BASIC_NOT_IMPLEMENTED);
-        return;
-    }
-
     int nArgs = (int)rPar.Count();
     if ( nArgs != 3 )
     {
@@ -4087,13 +4052,6 @@ RTLFUNC(DDEExecute)
     (void)pBasic;
     (void)bWrite;
 
-    // No DDE for "virtual" portal users
-    if( needSecurityRestrictions() )
-    {
-        StarBASIC::Error(ERRCODE_BASIC_NOT_IMPLEMENTED);
-        return;
-    }
-
     rPar.Get(0)->PutEmpty();
     int nArgs = (int)rPar.Count();
     if ( nArgs != 3 )
@@ -4116,13 +4074,6 @@ RTLFUNC(DDEPoke)
     (void)pBasic;
     (void)bWrite;
 
-    // No DDE for "virtual" portal users
-    if( needSecurityRestrictions() )
-    {
-        StarBASIC::Error(ERRCODE_BASIC_NOT_IMPLEMENTED);
-        return;
-    }
-
     rPar.Get(0)->PutEmpty();
     int nArgs = (int)rPar.Count();
     if ( nArgs != 4 )
diff --git a/basic/source/runtime/runtime.cxx b/basic/source/runtime/runtime.cxx
index e6dfa20..239d707 100644
--- a/basic/source/runtime/runtime.cxx
+++ b/basic/source/runtime/runtime.cxx
@@ -1285,13 +1285,6 @@ void SbiRuntime::DllCall
       SbxDataType eResType,     // return value
       bool bCDecl )         // true: according to C-conventions
 {
-    // No DllCall for "virtual" portal users
-    if( needSecurityRestrictions() )
-    {
-        StarBASIC::Error(ERRCODE_BASIC_NOT_IMPLEMENTED);
-        return;
-    }
-
     // NOT YET IMPLEMENTED
 
     SbxVariable* pRes = new SbxVariable( eResType );


More information about the Libreoffice-commits mailing list