xiaoding721
2024-09-11 e0d43661dc07fb9ec4fe856397a96ddc77cff132
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
Quintiq file version 2.0
#parent: #root
Method ReceiveConfigurationSuccessJoin (NamedValueTree nvt_i, NamedValue body_i, LibDEF_IntegrationEvent event_i)
{
  Description:
  [*
    Receive Configuration success-message to join domain, including accept from BootNode or acknowledgement from other nodes.
    Also exchange Metadata information by using GetChannelsMetadata.
  *]
  TextBody:
  [*
    // Jacky CHAN Apr-22-2016 (created)
    LibDEF_Util::EventLog( event_i, "Receiving join acknowledgement" );
    
    isFromBootNode := LibDEF_DataAccessor::GetBodyPropertyAsBoolean( nvt_i, LibDEF_DataAccessor::HANDLE_CONFIGURATION(), LibDEF_DataAccessor::HEADER_FROMBOOTNODE() );
    
    if( isFromBootNode )
    {
      // retrieve and save the assigned SystemGUID
      systemGUID := LibDEF_DataAccessor::GetBodyPropertyAsString( nvt_i, LibDEF_DataAccessor::HANDLE_CONFIGURATION(), LibDEF_DataAccessor::HEADER_SYSTEMGUID() );
      this.SystemLocal().ChangeKeySystemByGUID( systemGUID, event_i );
    
      // also update the reference
      this.SystemGUID( systemGUID );
    
      // retrieve and save the BootNode S-GUID
      bootNodeGUID    := LibDEF_DataAccessor::GetBodyPropertyAsString( nvt_i, LibDEF_DataAccessor::HANDLE_CONFIGURATION(), LibDEF_DataAccessor::HEADER_BOOTNODEGUID() );
      newBootNode     := LibDEF_System::FindSystemByGUID( this, bootNodeGUID );
      currentBootNode := this.BootNode();
    
      // a new node becomes BootNode
      if( isnull( newBootNode ) and isnull( currentBootNode ) )
      {
        // create BootNode System
        newBootNode := LibDEF_System::Create( this, bootNodeGUID );
        newBootNode.SetAsBootNode();
    
        LibDEF_Util::EventLog( event_i, "BootNode has been registered." );
      }
      // nothing has changed
      else if( newBootNode = currentBootNode )
      {
        LibDEF_Util::EventLog( event_i, "BootNode did not change." );
      }
      // an existing node becomes a BootNode
      else if( not isnull( newBootNode ) )
      {
        newBootNode.SetAsBootNode();
    
        LibDEF_Util::EventLog( event_i, "Another System has become the BootNode. BootNode has been updated." );
      }
    
      this.SyncFromRoutingTable( nvt_i, body_i, event_i );
    
      // Updates the IntegrationEvent with sender information (BootNode)
      event_i.Update( newBootNode );
    
      // inform other systems
      traverse( this.GetOtherPeers( false ), Elements, system )
      {
        this.SendConfigurationRequestJoinToPeer( system );
      }
    }
    
    // End of receive configuration success join
    LibDEF_IntegrationEvent::EventComplete( event_i );
    
    // exchange GetChannelsMetadata from the sender
    senderGUID := LibDEF_DataAccessor::GetHeaderPropertyAsString( nvt_i, LibDEF_DataAccessor::HEADER_SYSTEMGUID_FROM() );
    sender     := LibDEF_System::FindSystemByGUID( this, senderGUID );
    
    if( not isnull( sender ) )
    {
      localSystem        := this.SystemLocal();
      commonChannelNames := localSystem.GetCommonChannelNames( sender );
    
      if( commonChannelNames.Size() > 0 )
      {
        // send Request
        localSystem.SendMetadataRequestGetChannelsMetadata( sender );
    
        // send Success with default common Channels
        // The IntegrationEvent from argument event_i is for receive configuration success join event
        // Since we are sending another message, a new Event should be created (which is handled inside the method itself)
        localSystem.SendMetadataSuccessGetChannelsMetadata( commonChannelNames, sender, null( LibDEF_IntegrationEvent ) );
      }
    }
  *]
}