Search in sources :

Example 1 with IDataService

use of org.jumpmind.symmetric.service.IDataService in project symmetric-ds by JumpMind.

the class SymmetricAdmin method reloadNode.

private void reloadNode(CommandLine line, List<String> args) {
    String nodeId = popArg(args, "Node ID");
    boolean reverse = line.hasOption(OPTION_REVERSE);
    IDataService dataService = getSymmetricEngine().getDataService();
    String message = dataService.reloadNode(nodeId, reverse, "symadmin");
    System.out.println(message);
}
Also used : IDataService(org.jumpmind.symmetric.service.IDataService)

Example 2 with IDataService

use of org.jumpmind.symmetric.service.IDataService in project symmetric-ds by JumpMind.

the class RestService method sendSchemaImpl.

private SendSchemaResponse sendSchemaImpl(ISymmetricEngine engine, SendSchemaRequest request) {
    IConfigurationService configurationService = engine.getConfigurationService();
    INodeService nodeService = engine.getNodeService();
    ITriggerRouterService triggerRouterService = engine.getTriggerRouterService();
    IDataService dataService = engine.getDataService();
    SendSchemaResponse response = new SendSchemaResponse();
    org.jumpmind.symmetric.model.Node identity = nodeService.findIdentity();
    if (identity != null) {
        List<org.jumpmind.symmetric.model.Node> nodesToSendTo = new ArrayList<org.jumpmind.symmetric.model.Node>();
        List<String> nodeIds = request.getNodeIdsToSendTo();
        if (nodeIds == null || nodeIds.size() == 0) {
            nodeIds = new ArrayList<String>();
            String nodeGroupIdToSendTo = request.getNodeGroupIdToSendTo();
            if (isNotBlank(nodeGroupIdToSendTo)) {
                NodeGroupLink link = configurationService.getNodeGroupLinkFor(identity.getNodeGroupId(), nodeGroupIdToSendTo, false);
                if (link != null) {
                    Collection<org.jumpmind.symmetric.model.Node> nodes = nodeService.findEnabledNodesFromNodeGroup(nodeGroupIdToSendTo);
                    nodesToSendTo.addAll(nodes);
                } else {
                    log.warn("Could not send schema to all nodes in the '" + nodeGroupIdToSendTo + "' node group.  No node group link exists");
                }
            } else {
                log.warn("Could not send schema to nodes.  There are none that were provided and the nodeGroupIdToSendTo was also not provided");
            }
        } else {
            for (String nodeIdToValidate : nodeIds) {
                org.jumpmind.symmetric.model.Node node = nodeService.findNode(nodeIdToValidate);
                if (node != null) {
                    NodeGroupLink link = configurationService.getNodeGroupLinkFor(identity.getNodeGroupId(), node.getNodeGroupId(), false);
                    if (link != null) {
                        nodesToSendTo.add(node);
                    } else {
                        log.warn("Could not send schema to node '" + nodeIdToValidate + "'. No node group link exists");
                    }
                } else {
                    log.warn("Could not send schema to node '" + nodeIdToValidate + "'.  It was not present in the database");
                }
            }
        }
        Map<String, List<TableName>> results = response.getNodeIdsSentTo();
        List<String> nodeIdsToSendTo = toNodeIds(nodesToSendTo);
        for (String nodeId : nodeIdsToSendTo) {
            results.put(nodeId, new ArrayList<TableName>());
        }
        if (nodesToSendTo.size() > 0) {
            List<TableName> tablesToSend = request.getTablesToSend();
            List<TriggerRouter> triggerRouters = triggerRouterService.getTriggerRouters(true, false);
            for (TriggerRouter triggerRouter : triggerRouters) {
                Trigger trigger = triggerRouter.getTrigger();
                NodeGroupLink link = triggerRouter.getRouter().getNodeGroupLink();
                if (link.getSourceNodeGroupId().equals(identity.getNodeGroupId())) {
                    for (org.jumpmind.symmetric.model.Node node : nodesToSendTo) {
                        if (link.getTargetNodeGroupId().equals(node.getNodeGroupId())) {
                            if (tablesToSend == null || tablesToSend.size() == 0 || contains(trigger, tablesToSend)) {
                                dataService.sendSchema(node.getNodeId(), trigger.getSourceCatalogName(), trigger.getSourceSchemaName(), trigger.getSourceTableName(), false);
                                results.get(node.getNodeId()).add(new TableName(trigger.getSourceCatalogName(), trigger.getSourceSchemaName(), trigger.getSourceTableName()));
                            }
                        }
                    }
                }
            }
        }
    }
    return response;
}
Also used : Node(org.jumpmind.symmetric.web.rest.model.Node) NetworkedNode(org.jumpmind.symmetric.model.NetworkedNode) ArrayList(java.util.ArrayList) IConfigurationService(org.jumpmind.symmetric.service.IConfigurationService) Trigger(org.jumpmind.symmetric.model.Trigger) TriggerRouter(org.jumpmind.symmetric.model.TriggerRouter) List(java.util.List) ArrayList(java.util.ArrayList) EngineList(org.jumpmind.symmetric.web.rest.model.EngineList) NodeList(org.jumpmind.symmetric.web.rest.model.NodeList) NodeGroupLink(org.jumpmind.symmetric.model.NodeGroupLink) ITriggerRouterService(org.jumpmind.symmetric.service.ITriggerRouterService) IDataService(org.jumpmind.symmetric.service.IDataService) TableName(org.jumpmind.symmetric.web.rest.model.TableName) INodeService(org.jumpmind.symmetric.service.INodeService) SendSchemaResponse(org.jumpmind.symmetric.web.rest.model.SendSchemaResponse)

Example 3 with IDataService

use of org.jumpmind.symmetric.service.IDataService in project symmetric-ds by JumpMind.

the class SimpleIntegrationTest method test29SyncShellCommand.

@Test(timeout = 120000)
public void test29SyncShellCommand() throws Exception {
    logTestRunning();
    IDataService rootDataService = getServer().getDataService();
    IOutgoingBatchService rootOutgoingBatchService = getServer().getOutgoingBatchService();
    testFlag = false;
    String scriptData = "org.jumpmind.symmetric.test.SimpleIntegrationTest.testFlag=true;";
    rootDataService.sendScript(TestConstants.TEST_CLIENT_EXTERNAL_ID, scriptData, false);
    clientPull();
    OutgoingBatches batches = rootOutgoingBatchService.getOutgoingBatches(TestConstants.TEST_CLIENT_NODE.getNodeId(), false);
    assertEquals(0, batches.countBatches(true));
    assertTrue("Expected the testFlag static variable to have been set to true", testFlag);
}
Also used : IOutgoingBatchService(org.jumpmind.symmetric.service.IOutgoingBatchService) OutgoingBatches(org.jumpmind.symmetric.model.OutgoingBatches) IDataService(org.jumpmind.symmetric.service.IDataService) Test(org.junit.Test)

Aggregations

IDataService (org.jumpmind.symmetric.service.IDataService)3 ArrayList (java.util.ArrayList)1 List (java.util.List)1 NetworkedNode (org.jumpmind.symmetric.model.NetworkedNode)1 NodeGroupLink (org.jumpmind.symmetric.model.NodeGroupLink)1 OutgoingBatches (org.jumpmind.symmetric.model.OutgoingBatches)1 Trigger (org.jumpmind.symmetric.model.Trigger)1 TriggerRouter (org.jumpmind.symmetric.model.TriggerRouter)1 IConfigurationService (org.jumpmind.symmetric.service.IConfigurationService)1 INodeService (org.jumpmind.symmetric.service.INodeService)1 IOutgoingBatchService (org.jumpmind.symmetric.service.IOutgoingBatchService)1 ITriggerRouterService (org.jumpmind.symmetric.service.ITriggerRouterService)1 EngineList (org.jumpmind.symmetric.web.rest.model.EngineList)1 Node (org.jumpmind.symmetric.web.rest.model.Node)1 NodeList (org.jumpmind.symmetric.web.rest.model.NodeList)1 SendSchemaResponse (org.jumpmind.symmetric.web.rest.model.SendSchemaResponse)1 TableName (org.jumpmind.symmetric.web.rest.model.TableName)1 Test (org.junit.Test)1