4 // Copyright (C) 2005 Novell, Inc.
8 // Permission is hereby granted, free of charge, to any person obtaining a
9 // copy of this software and associated documentation files (the "Software"),
10 // to deal in the Software without restriction, including without limitation
11 // the rights to use, copy, modify, merge, publish, distribute, sublicense,
12 // and/or sell copies of the Software, and to permit persons to whom the
13 // Software is furnished to do so, subject to the following conditions:
15 // The above copyright notice and this permission notice shall be included in
16 // all copies or substantial portions of the Software.
18 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
23 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
24 // DEALINGS IN THE SOFTWARE.
28 using System
.Collections
;
29 using System
.Threading
;
30 using System
.Xml
.Serialization
;
34 namespace Beagle
.Daemon
{
36 [RequestMessage (typeof (DaemonInformationRequest
))]
37 public class DaemonInformationExecutor
: RequestMessageExecutor
{
39 public override ResponseMessage
Execute (RequestMessage req
)
41 DaemonInformationResponse response
= new DaemonInformationResponse ();
42 response
.Version
= ExternalStringsHack
.Version
;
43 response
.HumanReadableStatus
= Scheduler
.Global
.GetHumanReadableStatus ();
44 response
.IndexInformation
= QueryDriver
.GetIndexInformation ();
45 response
.IsIndexing
= QueryDriver
.IsIndexing
;
51 [RequestMessage (typeof (ShutdownRequest
))]
52 public class ShutdownExecutor
: RequestMessageExecutor
{
54 private void DoShutdown ()
56 Shutdown
.BeginShutdown ();
59 public override ResponseMessage
Execute (RequestMessage req
)
61 // Start the shutdown process in a separate thread
62 // to avoid a deadlock: BeginShutdown() waits until
63 // all worker process are finished, but this method
64 // itself is part of a worker.
65 ExceptionHandlingThread
.Start (new ThreadStart (DoShutdown
));
67 return new EmptyResponse ();
71 [RequestMessage (typeof (ReloadConfigRequest
))]
72 public class ReloadConfigExecutor
: RequestMessageExecutor
{
74 public override ResponseMessage
Execute (RequestMessage req
)
77 return new EmptyResponse ();
81 [RequestMessage (typeof (OptimizeIndexesRequest
))]
82 public class OptimizeIndexesExecutor
: RequestMessageExecutor
{
84 public override ResponseMessage
Execute (RequestMessage req
)
86 LuceneQueryable
.OptimizeAll ();
87 return new EmptyResponse ();