1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_svl.hxx"
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski #include <stdio.h>
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski #include <com/sun/star/ucb/XSimpleFileAccess.hpp>
30*b1cdbd2cSJim Jagielski #include <com/sun/star/ucb/XCommandEnvironment.hpp>
31*b1cdbd2cSJim Jagielski #include <com/sun/star/ucb/XContent.hpp>
32*b1cdbd2cSJim Jagielski #include <com/sun/star/ucb/InsertCommandArgument.hpp>
33*b1cdbd2cSJim Jagielski #include <com/sun/star/ucb/InteractiveIOException.hpp>
34*b1cdbd2cSJim Jagielski #include <com/sun/star/io/WrongFormatException.hpp>
35*b1cdbd2cSJim Jagielski 
36*b1cdbd2cSJim Jagielski #include <osl/time.h>
37*b1cdbd2cSJim Jagielski #include <osl/security.hxx>
38*b1cdbd2cSJim Jagielski #include <osl/socket.hxx>
39*b1cdbd2cSJim Jagielski 
40*b1cdbd2cSJim Jagielski #include <rtl/string.hxx>
41*b1cdbd2cSJim Jagielski #include <rtl/ustring.hxx>
42*b1cdbd2cSJim Jagielski #include <rtl/strbuf.hxx>
43*b1cdbd2cSJim Jagielski #include <rtl/ustrbuf.hxx>
44*b1cdbd2cSJim Jagielski 
45*b1cdbd2cSJim Jagielski #include <comphelper/processfactory.hxx>
46*b1cdbd2cSJim Jagielski #include <ucbhelper/content.hxx>
47*b1cdbd2cSJim Jagielski 
48*b1cdbd2cSJim Jagielski #include <tools/urlobj.hxx>
49*b1cdbd2cSJim Jagielski #include <tools/stream.hxx>
50*b1cdbd2cSJim Jagielski #include <unotools/bootstrap.hxx>
51*b1cdbd2cSJim Jagielski #include <unotools/streamwrap.hxx>
52*b1cdbd2cSJim Jagielski 
53*b1cdbd2cSJim Jagielski #include <unotools/useroptions.hxx>
54*b1cdbd2cSJim Jagielski 
55*b1cdbd2cSJim Jagielski #include <svl/sharecontrolfile.hxx>
56*b1cdbd2cSJim Jagielski 
57*b1cdbd2cSJim Jagielski using namespace ::com::sun::star;
58*b1cdbd2cSJim Jagielski 
59*b1cdbd2cSJim Jagielski namespace svt {
60*b1cdbd2cSJim Jagielski 
61*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------
ShareControlFile(const::rtl::OUString & aOrigURL,const uno::Reference<lang::XMultiServiceFactory> & xFactory)62*b1cdbd2cSJim Jagielski ShareControlFile::ShareControlFile( const ::rtl::OUString& aOrigURL, const uno::Reference< lang::XMultiServiceFactory >& xFactory )
63*b1cdbd2cSJim Jagielski : LockFileCommon( aOrigURL, xFactory, ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( ".~sharing." ) ) )
64*b1cdbd2cSJim Jagielski {
65*b1cdbd2cSJim Jagielski     OpenStream();
66*b1cdbd2cSJim Jagielski 
67*b1cdbd2cSJim Jagielski     if ( !IsValid() )
68*b1cdbd2cSJim Jagielski         throw io::NotConnectedException();
69*b1cdbd2cSJim Jagielski }
70*b1cdbd2cSJim Jagielski 
71*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------
~ShareControlFile()72*b1cdbd2cSJim Jagielski ShareControlFile::~ShareControlFile()
73*b1cdbd2cSJim Jagielski {
74*b1cdbd2cSJim Jagielski     try
75*b1cdbd2cSJim Jagielski     {
76*b1cdbd2cSJim Jagielski         Close();
77*b1cdbd2cSJim Jagielski     }
78*b1cdbd2cSJim Jagielski     catch( uno::Exception& )
79*b1cdbd2cSJim Jagielski     {}
80*b1cdbd2cSJim Jagielski }
81*b1cdbd2cSJim Jagielski 
82*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------
OpenStream()83*b1cdbd2cSJim Jagielski void ShareControlFile::OpenStream()
84*b1cdbd2cSJim Jagielski {
85*b1cdbd2cSJim Jagielski     // if it is called outside of constructor the mutex must be locked already
86*b1cdbd2cSJim Jagielski 
87*b1cdbd2cSJim Jagielski     if ( !m_xStream.is() && m_aURL.getLength() )
88*b1cdbd2cSJim Jagielski     {
89*b1cdbd2cSJim Jagielski 	    uno::Reference< ucb::XCommandEnvironment > xDummyEnv;
90*b1cdbd2cSJim Jagielski         ::ucbhelper::Content aContent = ::ucbhelper::Content( m_aURL, xDummyEnv );
91*b1cdbd2cSJim Jagielski 
92*b1cdbd2cSJim Jagielski         uno::Reference< ucb::XContentIdentifier > xContId( aContent.get().is() ? aContent.get()->getIdentifier() : 0 );
93*b1cdbd2cSJim Jagielski         if ( !xContId.is() || !xContId->getContentProviderScheme().equals( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "file" ) ) ) )
94*b1cdbd2cSJim Jagielski             throw io::IOException(); // the implementation supports only local files for now
95*b1cdbd2cSJim Jagielski 
96*b1cdbd2cSJim Jagielski         uno::Reference< io::XStream > xStream;
97*b1cdbd2cSJim Jagielski 
98*b1cdbd2cSJim Jagielski         // Currently the locking of the original document is intended to be used.
99*b1cdbd2cSJim Jagielski         // That means that the shared file should be accessed only when the original document is locked and only by user who has locked the document.
100*b1cdbd2cSJim Jagielski         // TODO/LATER: should the own file locking be used?
101*b1cdbd2cSJim Jagielski 
102*b1cdbd2cSJim Jagielski         try
103*b1cdbd2cSJim Jagielski         {
104*b1cdbd2cSJim Jagielski             xStream = aContent.openWriteableStreamNoLock();
105*b1cdbd2cSJim Jagielski         }
106*b1cdbd2cSJim Jagielski         catch ( ucb::InteractiveIOException const & e )
107*b1cdbd2cSJim Jagielski         {
108*b1cdbd2cSJim Jagielski             if ( e.Code == ucb::IOErrorCode_NOT_EXISTING )
109*b1cdbd2cSJim Jagielski             {
110*b1cdbd2cSJim Jagielski                 // Create file...
111*b1cdbd2cSJim Jagielski                 SvMemoryStream aStream(0,0);
112*b1cdbd2cSJim Jagielski                 uno::Reference< io::XInputStream > xInput( new ::utl::OInputStreamWrapper( aStream ) );
113*b1cdbd2cSJim Jagielski                 ucb::InsertCommandArgument aInsertArg;
114*b1cdbd2cSJim Jagielski                 aInsertArg.Data = xInput;
115*b1cdbd2cSJim Jagielski                 aInsertArg.ReplaceExisting = sal_False;
116*b1cdbd2cSJim Jagielski                 aContent.executeCommand( rtl::OUString::createFromAscii( "insert" ), uno::makeAny( aInsertArg ) );
117*b1cdbd2cSJim Jagielski 
118*b1cdbd2cSJim Jagielski                 // try to let the file be hidden if possible
119*b1cdbd2cSJim Jagielski                 try {
120*b1cdbd2cSJim Jagielski                     aContent.setPropertyValue( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "IsHidden" ) ), uno::makeAny( sal_True ) );
121*b1cdbd2cSJim Jagielski                 } catch( uno::Exception& ) {}
122*b1cdbd2cSJim Jagielski 
123*b1cdbd2cSJim Jagielski                 // Try to open one more time
124*b1cdbd2cSJim Jagielski                 xStream = aContent.openWriteableStreamNoLock();
125*b1cdbd2cSJim Jagielski             }
126*b1cdbd2cSJim Jagielski             else
127*b1cdbd2cSJim Jagielski                 throw;
128*b1cdbd2cSJim Jagielski         }
129*b1cdbd2cSJim Jagielski 
130*b1cdbd2cSJim Jagielski         m_xSeekable.set( xStream, uno::UNO_QUERY_THROW );
131*b1cdbd2cSJim Jagielski         m_xInputStream.set( xStream->getInputStream(), uno::UNO_QUERY_THROW );
132*b1cdbd2cSJim Jagielski         m_xOutputStream.set( xStream->getOutputStream(), uno::UNO_QUERY_THROW );
133*b1cdbd2cSJim Jagielski         m_xTruncate.set( m_xOutputStream, uno::UNO_QUERY_THROW );
134*b1cdbd2cSJim Jagielski         m_xStream = xStream;
135*b1cdbd2cSJim Jagielski     }
136*b1cdbd2cSJim Jagielski }
137*b1cdbd2cSJim Jagielski 
138*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------
Close()139*b1cdbd2cSJim Jagielski void ShareControlFile::Close()
140*b1cdbd2cSJim Jagielski {
141*b1cdbd2cSJim Jagielski     // if it is called outside of destructor the mutex must be locked
142*b1cdbd2cSJim Jagielski 
143*b1cdbd2cSJim Jagielski     if ( m_xStream.is() )
144*b1cdbd2cSJim Jagielski     {
145*b1cdbd2cSJim Jagielski         try
146*b1cdbd2cSJim Jagielski         {
147*b1cdbd2cSJim Jagielski             if ( m_xInputStream.is() )
148*b1cdbd2cSJim Jagielski                 m_xInputStream->closeInput();
149*b1cdbd2cSJim Jagielski             if ( m_xOutputStream.is() )
150*b1cdbd2cSJim Jagielski                 m_xOutputStream->closeOutput();
151*b1cdbd2cSJim Jagielski         }
152*b1cdbd2cSJim Jagielski         catch( uno::Exception& )
153*b1cdbd2cSJim Jagielski         {}
154*b1cdbd2cSJim Jagielski 
155*b1cdbd2cSJim Jagielski         m_xStream = uno::Reference< io::XStream >();
156*b1cdbd2cSJim Jagielski         m_xInputStream = uno::Reference< io::XInputStream >();
157*b1cdbd2cSJim Jagielski         m_xOutputStream = uno::Reference< io::XOutputStream >();
158*b1cdbd2cSJim Jagielski         m_xSeekable = uno::Reference< io::XSeekable >();
159*b1cdbd2cSJim Jagielski         m_xTruncate = uno::Reference< io::XTruncate >();
160*b1cdbd2cSJim Jagielski         m_aUsersData.realloc( 0 );
161*b1cdbd2cSJim Jagielski     }
162*b1cdbd2cSJim Jagielski }
163*b1cdbd2cSJim Jagielski 
164*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------
GetUsersData()165*b1cdbd2cSJim Jagielski uno::Sequence< uno::Sequence< ::rtl::OUString > > ShareControlFile::GetUsersData()
166*b1cdbd2cSJim Jagielski {
167*b1cdbd2cSJim Jagielski     ::osl::MutexGuard aGuard( m_aMutex );
168*b1cdbd2cSJim Jagielski 
169*b1cdbd2cSJim Jagielski     if ( !IsValid() )
170*b1cdbd2cSJim Jagielski         throw io::NotConnectedException();
171*b1cdbd2cSJim Jagielski 
172*b1cdbd2cSJim Jagielski     if ( !m_aUsersData.getLength() )
173*b1cdbd2cSJim Jagielski     {
174*b1cdbd2cSJim Jagielski         sal_Int64 nLength = m_xSeekable->getLength();
175*b1cdbd2cSJim Jagielski         if ( nLength > SAL_MAX_INT32 )
176*b1cdbd2cSJim Jagielski             throw uno::RuntimeException();
177*b1cdbd2cSJim Jagielski 
178*b1cdbd2cSJim Jagielski         uno::Sequence< sal_Int8 > aBuffer( (sal_Int32)nLength );
179*b1cdbd2cSJim Jagielski         m_xSeekable->seek( 0 );
180*b1cdbd2cSJim Jagielski 
181*b1cdbd2cSJim Jagielski         sal_Int32 nRead = m_xInputStream->readBytes( aBuffer, (sal_Int32)nLength );
182*b1cdbd2cSJim Jagielski         nLength -= nRead;
183*b1cdbd2cSJim Jagielski         while ( nLength > 0 )
184*b1cdbd2cSJim Jagielski         {
185*b1cdbd2cSJim Jagielski             uno::Sequence< sal_Int8 > aTmpBuf( (sal_Int32)nLength );
186*b1cdbd2cSJim Jagielski             nRead = m_xInputStream->readBytes( aTmpBuf, (sal_Int32)nLength );
187*b1cdbd2cSJim Jagielski             if ( nRead > nLength )
188*b1cdbd2cSJim Jagielski                 throw uno::RuntimeException();
189*b1cdbd2cSJim Jagielski 
190*b1cdbd2cSJim Jagielski             for ( sal_Int32 nInd = 0; nInd < nRead; nInd++ )
191*b1cdbd2cSJim Jagielski                 aBuffer[aBuffer.getLength() - (sal_Int32)nLength + nInd] = aTmpBuf[nInd];
192*b1cdbd2cSJim Jagielski             nLength -= nRead;
193*b1cdbd2cSJim Jagielski         }
194*b1cdbd2cSJim Jagielski 
195*b1cdbd2cSJim Jagielski         m_aUsersData = ParseList( aBuffer );
196*b1cdbd2cSJim Jagielski     }
197*b1cdbd2cSJim Jagielski 
198*b1cdbd2cSJim Jagielski     return m_aUsersData;
199*b1cdbd2cSJim Jagielski }
200*b1cdbd2cSJim Jagielski 
201*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------
SetUsersDataAndStore(const uno::Sequence<uno::Sequence<::rtl::OUString>> & aUsersData)202*b1cdbd2cSJim Jagielski void ShareControlFile::SetUsersDataAndStore( const uno::Sequence< uno::Sequence< ::rtl::OUString > >& aUsersData )
203*b1cdbd2cSJim Jagielski {
204*b1cdbd2cSJim Jagielski     ::osl::MutexGuard aGuard( m_aMutex );
205*b1cdbd2cSJim Jagielski 
206*b1cdbd2cSJim Jagielski     if ( !IsValid() )
207*b1cdbd2cSJim Jagielski         throw io::NotConnectedException();
208*b1cdbd2cSJim Jagielski 
209*b1cdbd2cSJim Jagielski     if ( !m_xTruncate.is() || !m_xOutputStream.is() || !m_xSeekable.is() )
210*b1cdbd2cSJim Jagielski         throw uno::RuntimeException();
211*b1cdbd2cSJim Jagielski 
212*b1cdbd2cSJim Jagielski     m_xTruncate->truncate();
213*b1cdbd2cSJim Jagielski     m_xSeekable->seek( 0 );
214*b1cdbd2cSJim Jagielski 
215*b1cdbd2cSJim Jagielski     ::rtl::OUStringBuffer aBuffer;
216*b1cdbd2cSJim Jagielski     for ( sal_Int32 nInd = 0; nInd < aUsersData.getLength(); nInd++ )
217*b1cdbd2cSJim Jagielski     {
218*b1cdbd2cSJim Jagielski         if ( aUsersData[nInd].getLength() != SHARED_ENTRYSIZE )
219*b1cdbd2cSJim Jagielski             throw lang::IllegalArgumentException();
220*b1cdbd2cSJim Jagielski 
221*b1cdbd2cSJim Jagielski         for ( sal_Int32 nEntryInd = 0; nEntryInd < SHARED_ENTRYSIZE; nEntryInd++ )
222*b1cdbd2cSJim Jagielski         {
223*b1cdbd2cSJim Jagielski             aBuffer.append( EscapeCharacters( aUsersData[nInd][nEntryInd] ) );
224*b1cdbd2cSJim Jagielski             if ( nEntryInd < SHARED_ENTRYSIZE - 1 )
225*b1cdbd2cSJim Jagielski                 aBuffer.append( (sal_Unicode)',' );
226*b1cdbd2cSJim Jagielski             else
227*b1cdbd2cSJim Jagielski                 aBuffer.append( (sal_Unicode)';' );
228*b1cdbd2cSJim Jagielski         }
229*b1cdbd2cSJim Jagielski     }
230*b1cdbd2cSJim Jagielski 
231*b1cdbd2cSJim Jagielski     ::rtl::OString aStringData( ::rtl::OUStringToOString( aBuffer.makeStringAndClear(), RTL_TEXTENCODING_UTF8 ) );
232*b1cdbd2cSJim Jagielski     uno::Sequence< sal_Int8 > aData( (sal_Int8*)aStringData.getStr(), aStringData.getLength() );
233*b1cdbd2cSJim Jagielski     m_xOutputStream->writeBytes( aData );
234*b1cdbd2cSJim Jagielski     m_aUsersData = aUsersData;
235*b1cdbd2cSJim Jagielski }
236*b1cdbd2cSJim Jagielski 
237*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------
InsertOwnEntry()238*b1cdbd2cSJim Jagielski uno::Sequence< ::rtl::OUString > ShareControlFile::InsertOwnEntry()
239*b1cdbd2cSJim Jagielski {
240*b1cdbd2cSJim Jagielski     ::osl::MutexGuard aGuard( m_aMutex );
241*b1cdbd2cSJim Jagielski 
242*b1cdbd2cSJim Jagielski     if ( !IsValid() )
243*b1cdbd2cSJim Jagielski         throw io::NotConnectedException();
244*b1cdbd2cSJim Jagielski 
245*b1cdbd2cSJim Jagielski     GetUsersData();
246*b1cdbd2cSJim Jagielski     uno::Sequence< ::uno::Sequence< ::rtl::OUString > > aNewData( m_aUsersData.getLength() + 1 );
247*b1cdbd2cSJim Jagielski     uno::Sequence< ::rtl::OUString > aNewEntry = GenerateOwnEntry();
248*b1cdbd2cSJim Jagielski 
249*b1cdbd2cSJim Jagielski     sal_Bool bExists = sal_False;
250*b1cdbd2cSJim Jagielski     sal_Int32 nNewInd = 0;
251*b1cdbd2cSJim Jagielski     for ( sal_Int32 nInd = 0; nInd < m_aUsersData.getLength(); nInd++ )
252*b1cdbd2cSJim Jagielski     {
253*b1cdbd2cSJim Jagielski         if ( m_aUsersData[nInd].getLength() == SHARED_ENTRYSIZE )
254*b1cdbd2cSJim Jagielski         {
255*b1cdbd2cSJim Jagielski             if ( m_aUsersData[nInd][SHARED_LOCALHOST_ID] == aNewEntry[SHARED_LOCALHOST_ID]
256*b1cdbd2cSJim Jagielski               && m_aUsersData[nInd][SHARED_SYSUSERNAME_ID] == aNewEntry[SHARED_SYSUSERNAME_ID]
257*b1cdbd2cSJim Jagielski               && m_aUsersData[nInd][SHARED_USERURL_ID] == aNewEntry[SHARED_USERURL_ID] )
258*b1cdbd2cSJim Jagielski             {
259*b1cdbd2cSJim Jagielski                 if ( !bExists )
260*b1cdbd2cSJim Jagielski                 {
261*b1cdbd2cSJim Jagielski                     aNewData[nNewInd] = aNewEntry;
262*b1cdbd2cSJim Jagielski                     bExists = sal_True;
263*b1cdbd2cSJim Jagielski                 }
264*b1cdbd2cSJim Jagielski             }
265*b1cdbd2cSJim Jagielski             else
266*b1cdbd2cSJim Jagielski             {
267*b1cdbd2cSJim Jagielski                 aNewData[nNewInd] = m_aUsersData[nInd];
268*b1cdbd2cSJim Jagielski             }
269*b1cdbd2cSJim Jagielski 
270*b1cdbd2cSJim Jagielski             nNewInd++;
271*b1cdbd2cSJim Jagielski         }
272*b1cdbd2cSJim Jagielski     }
273*b1cdbd2cSJim Jagielski 
274*b1cdbd2cSJim Jagielski     if ( !bExists )
275*b1cdbd2cSJim Jagielski         aNewData[nNewInd++] = aNewEntry;
276*b1cdbd2cSJim Jagielski 
277*b1cdbd2cSJim Jagielski     aNewData.realloc( nNewInd );
278*b1cdbd2cSJim Jagielski     SetUsersDataAndStore( aNewData );
279*b1cdbd2cSJim Jagielski 
280*b1cdbd2cSJim Jagielski     return aNewEntry;
281*b1cdbd2cSJim Jagielski }
282*b1cdbd2cSJim Jagielski 
283*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------
HasOwnEntry()284*b1cdbd2cSJim Jagielski bool ShareControlFile::HasOwnEntry()
285*b1cdbd2cSJim Jagielski {
286*b1cdbd2cSJim Jagielski     ::osl::MutexGuard aGuard( m_aMutex );
287*b1cdbd2cSJim Jagielski 
288*b1cdbd2cSJim Jagielski     if ( !IsValid() )
289*b1cdbd2cSJim Jagielski     {
290*b1cdbd2cSJim Jagielski         throw io::NotConnectedException();
291*b1cdbd2cSJim Jagielski     }
292*b1cdbd2cSJim Jagielski 
293*b1cdbd2cSJim Jagielski     GetUsersData();
294*b1cdbd2cSJim Jagielski     uno::Sequence< ::rtl::OUString > aEntry = GenerateOwnEntry();
295*b1cdbd2cSJim Jagielski 
296*b1cdbd2cSJim Jagielski     for ( sal_Int32 nInd = 0; nInd < m_aUsersData.getLength(); ++nInd )
297*b1cdbd2cSJim Jagielski     {
298*b1cdbd2cSJim Jagielski         if ( m_aUsersData[nInd].getLength() == SHARED_ENTRYSIZE &&
299*b1cdbd2cSJim Jagielski              m_aUsersData[nInd][SHARED_LOCALHOST_ID] == aEntry[SHARED_LOCALHOST_ID] &&
300*b1cdbd2cSJim Jagielski              m_aUsersData[nInd][SHARED_SYSUSERNAME_ID] == aEntry[SHARED_SYSUSERNAME_ID] &&
301*b1cdbd2cSJim Jagielski              m_aUsersData[nInd][SHARED_USERURL_ID] == aEntry[SHARED_USERURL_ID] )
302*b1cdbd2cSJim Jagielski         {
303*b1cdbd2cSJim Jagielski             return true;
304*b1cdbd2cSJim Jagielski         }
305*b1cdbd2cSJim Jagielski     }
306*b1cdbd2cSJim Jagielski 
307*b1cdbd2cSJim Jagielski     return false;
308*b1cdbd2cSJim Jagielski }
309*b1cdbd2cSJim Jagielski 
310*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------
RemoveEntry(const uno::Sequence<::rtl::OUString> & aArgEntry)311*b1cdbd2cSJim Jagielski void ShareControlFile::RemoveEntry( const uno::Sequence< ::rtl::OUString >& aArgEntry )
312*b1cdbd2cSJim Jagielski {
313*b1cdbd2cSJim Jagielski     ::osl::MutexGuard aGuard( m_aMutex );
314*b1cdbd2cSJim Jagielski 
315*b1cdbd2cSJim Jagielski     if ( !IsValid() )
316*b1cdbd2cSJim Jagielski         throw io::NotConnectedException();
317*b1cdbd2cSJim Jagielski 
318*b1cdbd2cSJim Jagielski     GetUsersData();
319*b1cdbd2cSJim Jagielski 
320*b1cdbd2cSJim Jagielski     uno::Sequence< ::rtl::OUString > aEntry = aArgEntry;
321*b1cdbd2cSJim Jagielski     if ( aEntry.getLength() != SHARED_ENTRYSIZE )
322*b1cdbd2cSJim Jagielski         aEntry = GenerateOwnEntry();
323*b1cdbd2cSJim Jagielski 
324*b1cdbd2cSJim Jagielski     uno::Sequence< ::uno::Sequence< ::rtl::OUString > > aNewData( m_aUsersData.getLength() + 1 );
325*b1cdbd2cSJim Jagielski 
326*b1cdbd2cSJim Jagielski     sal_Int32 nNewInd = 0;
327*b1cdbd2cSJim Jagielski     for ( sal_Int32 nInd = 0; nInd < m_aUsersData.getLength(); nInd++ )
328*b1cdbd2cSJim Jagielski     {
329*b1cdbd2cSJim Jagielski         if ( m_aUsersData[nInd].getLength() == SHARED_ENTRYSIZE )
330*b1cdbd2cSJim Jagielski         {
331*b1cdbd2cSJim Jagielski             if ( m_aUsersData[nInd][SHARED_LOCALHOST_ID] != aEntry[SHARED_LOCALHOST_ID]
332*b1cdbd2cSJim Jagielski               || m_aUsersData[nInd][SHARED_SYSUSERNAME_ID] != aEntry[SHARED_SYSUSERNAME_ID]
333*b1cdbd2cSJim Jagielski               || m_aUsersData[nInd][SHARED_USERURL_ID] != aEntry[SHARED_USERURL_ID] )
334*b1cdbd2cSJim Jagielski             {
335*b1cdbd2cSJim Jagielski                 aNewData[nNewInd] = m_aUsersData[nInd];
336*b1cdbd2cSJim Jagielski                 nNewInd++;
337*b1cdbd2cSJim Jagielski             }
338*b1cdbd2cSJim Jagielski         }
339*b1cdbd2cSJim Jagielski     }
340*b1cdbd2cSJim Jagielski 
341*b1cdbd2cSJim Jagielski     aNewData.realloc( nNewInd );
342*b1cdbd2cSJim Jagielski     SetUsersDataAndStore( aNewData );
343*b1cdbd2cSJim Jagielski 
344*b1cdbd2cSJim Jagielski     if ( !nNewInd )
345*b1cdbd2cSJim Jagielski     {
346*b1cdbd2cSJim Jagielski         // try to remove the file if it is empty
347*b1cdbd2cSJim Jagielski         RemoveFile();
348*b1cdbd2cSJim Jagielski     }
349*b1cdbd2cSJim Jagielski }
350*b1cdbd2cSJim Jagielski 
351*b1cdbd2cSJim Jagielski // ----------------------------------------------------------------------
RemoveFile()352*b1cdbd2cSJim Jagielski void ShareControlFile::RemoveFile()
353*b1cdbd2cSJim Jagielski {
354*b1cdbd2cSJim Jagielski     ::osl::MutexGuard aGuard( m_aMutex );
355*b1cdbd2cSJim Jagielski 
356*b1cdbd2cSJim Jagielski     if ( !IsValid() )
357*b1cdbd2cSJim Jagielski         throw io::NotConnectedException();
358*b1cdbd2cSJim Jagielski 
359*b1cdbd2cSJim Jagielski     Close();
360*b1cdbd2cSJim Jagielski 
361*b1cdbd2cSJim Jagielski     uno::Reference< lang::XMultiServiceFactory > xFactory = ::comphelper::getProcessServiceFactory();
362*b1cdbd2cSJim Jagielski     uno::Reference< ::com::sun::star::ucb::XSimpleFileAccess > xSimpleFileAccess(
363*b1cdbd2cSJim Jagielski         xFactory->createInstance( ::rtl::OUString::createFromAscii("com.sun.star.ucb.SimpleFileAccess") ),
364*b1cdbd2cSJim Jagielski         uno::UNO_QUERY_THROW );
365*b1cdbd2cSJim Jagielski     xSimpleFileAccess->kill( m_aURL );
366*b1cdbd2cSJim Jagielski }
367*b1cdbd2cSJim Jagielski 
368*b1cdbd2cSJim Jagielski } // namespace svt
369*b1cdbd2cSJim Jagielski 
370