opcuaServer.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. /*
  2. ============================================================================
  3. Name : opcuaServer.c
  4. Author :
  5. Version :
  6. Copyright : Your copyright notice
  7. Description :
  8. ============================================================================
  9. */
  10. #include <stdio.h>
  11. #include <stdlib.h>
  12. //#include "opcua_binaryEncDec.h"
  13. #include "opcua_builtInDatatypes.h"
  14. #include "opcua_transportLayer.h"
  15. #include "opcua_types.h"
  16. #include <sys/socket.h>
  17. #include <netinet/in.h>
  18. int main(void)
  19. {
  20. puts("OPC ua Stack");
  21. //struct BED_ApplicationDescription nStruct;
  22. //UA_String s;
  23. puts("running tests...");
  24. TL_getMessageHeader_test();
  25. //TL_getHELMessage_test();
  26. puts("...done");
  27. server_init();
  28. server_run();
  29. return EXIT_SUCCESS;
  30. }
  31. void server_init()
  32. {
  33. puts("starting demo Server");
  34. //call listen
  35. }
  36. void server_run()
  37. {
  38. int server_state = 0;
  39. int recv_data = 0;
  40. int send_data = 1;
  41. int new_client = 2;
  42. int new_request = 3;
  43. char buf[8192];
  44. struct sockaddr_in self;
  45. int sockfd;
  46. int clientfd;
  47. struct sockaddr_in client_addr;
  48. int addrlen=sizeof(client_addr);
  49. /*---Create streaming socket---*/
  50. if ( (sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0 )
  51. {
  52. puts("socket error");
  53. }
  54. bzero(&self, sizeof(self));
  55. self.sin_family = AF_INET;
  56. self.sin_port = htons(4840);
  57. self.sin_addr.s_addr = htonl(INADDR_ANY);
  58. if(bind(sockfd, self, sizeof( self)) < 0) {
  59. //Fehler bei bind()
  60. }
  61. /*---Make it a "listening socket"---*/
  62. if ( listen(sockfd, 1) != 0 )
  63. {
  64. puts("listen error");
  65. }
  66. clientfd = accept(sockfd, (struct sockaddr*)&client_addr, &addrlen);
  67. server_state = 0;
  68. while(1)
  69. {
  70. //call recv (nonblocking)
  71. //call TL_getPacketType
  72. //if newData
  73. //
  74. UA_connection connection;
  75. AD_RawMessage *rawMessage;
  76. rawMessage->message = buf;
  77. rawMessage->length = 0;
  78. switch(server_state)
  79. {
  80. recv_data :
  81. {
  82. //call receive function
  83. rawMessage->length = recv(sockfd,buf,8192,0);
  84. if(rawMessage->length > 0)
  85. {
  86. server_state = new_client;
  87. }
  88. break;
  89. }
  90. send_data :
  91. {
  92. //call send function
  93. break;
  94. }
  95. new_client :
  96. {
  97. if(connection.transportLayer.connectionState != connectionState_ESTABLISHED)
  98. {
  99. TL_open(connection,rawMessage);
  100. }
  101. /* else
  102. {
  103. SL_open(connection,rawMessage);
  104. }
  105. */
  106. }
  107. new_request :
  108. {
  109. break;
  110. }
  111. }
  112. //if newClient
  113. //TL_processHELMessage(&connection,);
  114. //--------
  115. //call listen
  116. }
  117. }