~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to plugin/replication_dictionary/streams.cc

This patch adds the following functionality:

* Removes the need to manually enable replicators in order
  for an applier to work.
* Removes the enabled/disabled setting of both transaction
  applier plugins and transaction replicator plugins
* Pairs a replicator with an applier into a "ReplicationStream"
  and removes all checks for "enabled" replicators and appliers
* Allows modules that implement a TransactionApplier (such as
  the transaction_log module) to specify which replicator to
  use via a configuration variable.  For instance, the transaction
  log module now has --transaction-log-use-replicator=[default|filtered..]
  instead of the user having to do --default-replicator-enable and such
* Adds a new data dictionary table for REPLICATION_STREAMS, which
  allows querying of activated replication-to-applier streams
  managed by drizzled::ReplicationServices

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
 
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
 
3
 *
 
4
 * Copyright (c) 2010 Jay Pipes <jaypipes@gmail.com>
 
5
 * All rights reserved.
 
6
 *
 
7
 * Redistribution and use in source and binary forms, with or without
 
8
 * modification, are permitted provided that the following conditions are met:
 
9
 *
 
10
 *   * Redistributions of source code must retain the above copyright notice,
 
11
 *     this list of conditions and the following disclaimer.
 
12
 *   * Redistributions in binary form must reproduce the above copyright notice,
 
13
 *     this list of conditions and the following disclaimer in the documentation
 
14
 *     and/or other materials provided with the distribution.
 
15
 *   * Neither the name of Drizzle nor the names of its contributors
 
16
 *     may be used to endorse or promote products derived from this software
 
17
 *     without specific prior written permission.
 
18
 *
 
19
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 
20
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 
21
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 
22
 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
 
23
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 
24
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 
25
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 
26
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 
27
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 
28
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
 
29
 * THE POSSIBILITY OF SUCH DAMAGE.
 
30
 */
 
31
 
 
32
#include "config.h"
 
33
#include "streams.h"
 
34
 
 
35
#include <drizzled/plugin/transaction_replicator.h>
 
36
#include <drizzled/plugin/transaction_applier.h>
 
37
 
 
38
using namespace std;
 
39
using namespace drizzled;
 
40
 
 
41
ReplicationStreamsTool::ReplicationStreamsTool() :
 
42
  plugin::TableFunction("DATA_DICTIONARY", "REPLICATION_STREAMS")
 
43
{
 
44
  add_field("REPLICATOR");
 
45
  add_field("APPLIER");
 
46
}
 
47
 
 
48
ReplicationStreamsTool::Generator::Generator(Field **arg) :
 
49
  plugin::TableFunction::Generator(arg)
 
50
{
 
51
  ReplicationServices &replication_services= ReplicationServices::singleton();
 
52
  ReplicationServices::ReplicationStreams &replication_streams=
 
53
    replication_services.getReplicationStreams();
 
54
 
 
55
  it= replication_streams.begin();
 
56
  end= replication_streams.end();
 
57
}
 
58
 
 
59
bool ReplicationStreamsTool::Generator::populate()
 
60
{
 
61
  if (it == end)
 
62
    return false;
 
63
 
 
64
  plugin::TransactionReplicator *replicator= (*it).first;
 
65
  plugin::TransactionApplier *applier= (*it).second;
 
66
 
 
67
  /* REPLICATOR */
 
68
  push(replicator->getName());
 
69
 
 
70
  /* APPLIER */
 
71
  push(applier->getName());
 
72
 
 
73
  ++it;
 
74
 
 
75
  return true;
 
76
}