sidekick-client 0.2.1 → 0.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (162) hide show
  1. data/VERSION +1 -1
  2. data/lib/sidekick/client/sidekick_client.rb +0 -3
  3. data/lib/sidekick/shared/sidekick_queue_publisher.rb +1 -1
  4. data/sidekick-client.gemspec +1 -158
  5. metadata +1 -158
  6. data/lib/ext/eventmachine-0.12.10/.gitignore +0 -14
  7. data/lib/ext/eventmachine-0.12.10/README +0 -82
  8. data/lib/ext/eventmachine-0.12.10/Rakefile +0 -374
  9. data/lib/ext/eventmachine-0.12.10/docs/COPYING +0 -60
  10. data/lib/ext/eventmachine-0.12.10/docs/ChangeLog +0 -211
  11. data/lib/ext/eventmachine-0.12.10/docs/DEFERRABLES +0 -133
  12. data/lib/ext/eventmachine-0.12.10/docs/EPOLL +0 -141
  13. data/lib/ext/eventmachine-0.12.10/docs/GNU +0 -281
  14. data/lib/ext/eventmachine-0.12.10/docs/INSTALL +0 -13
  15. data/lib/ext/eventmachine-0.12.10/docs/KEYBOARD +0 -38
  16. data/lib/ext/eventmachine-0.12.10/docs/LEGAL +0 -25
  17. data/lib/ext/eventmachine-0.12.10/docs/LIGHTWEIGHT_CONCURRENCY +0 -70
  18. data/lib/ext/eventmachine-0.12.10/docs/PURE_RUBY +0 -75
  19. data/lib/ext/eventmachine-0.12.10/docs/RELEASE_NOTES +0 -94
  20. data/lib/ext/eventmachine-0.12.10/docs/SMTP +0 -2
  21. data/lib/ext/eventmachine-0.12.10/docs/SPAWNED_PROCESSES +0 -89
  22. data/lib/ext/eventmachine-0.12.10/docs/TODO +0 -8
  23. data/lib/ext/eventmachine-0.12.10/eventmachine.gemspec +0 -40
  24. data/lib/ext/eventmachine-0.12.10/examples/ex_channel.rb +0 -43
  25. data/lib/ext/eventmachine-0.12.10/examples/ex_queue.rb +0 -2
  26. data/lib/ext/eventmachine-0.12.10/examples/helper.rb +0 -2
  27. data/lib/ext/eventmachine-0.12.10/ext/binder.cpp +0 -125
  28. data/lib/ext/eventmachine-0.12.10/ext/binder.h +0 -46
  29. data/lib/ext/eventmachine-0.12.10/ext/cmain.cpp +0 -827
  30. data/lib/ext/eventmachine-0.12.10/ext/cplusplus.cpp +0 -202
  31. data/lib/ext/eventmachine-0.12.10/ext/ed.cpp +0 -1893
  32. data/lib/ext/eventmachine-0.12.10/ext/ed.h +0 -424
  33. data/lib/ext/eventmachine-0.12.10/ext/em.cpp +0 -2282
  34. data/lib/ext/eventmachine-0.12.10/ext/em.h +0 -232
  35. data/lib/ext/eventmachine-0.12.10/ext/emwin.cpp +0 -300
  36. data/lib/ext/eventmachine-0.12.10/ext/emwin.h +0 -94
  37. data/lib/ext/eventmachine-0.12.10/ext/epoll.cpp +0 -26
  38. data/lib/ext/eventmachine-0.12.10/ext/epoll.h +0 -25
  39. data/lib/ext/eventmachine-0.12.10/ext/eventmachine.h +0 -122
  40. data/lib/ext/eventmachine-0.12.10/ext/eventmachine_cpp.h +0 -96
  41. data/lib/ext/eventmachine-0.12.10/ext/extconf.rb +0 -148
  42. data/lib/ext/eventmachine-0.12.10/ext/fastfilereader/extconf.rb +0 -83
  43. data/lib/ext/eventmachine-0.12.10/ext/fastfilereader/mapper.cpp +0 -214
  44. data/lib/ext/eventmachine-0.12.10/ext/fastfilereader/mapper.h +0 -59
  45. data/lib/ext/eventmachine-0.12.10/ext/fastfilereader/rubymain.cpp +0 -127
  46. data/lib/ext/eventmachine-0.12.10/ext/files.cpp +0 -94
  47. data/lib/ext/eventmachine-0.12.10/ext/files.h +0 -65
  48. data/lib/ext/eventmachine-0.12.10/ext/kb.cpp +0 -81
  49. data/lib/ext/eventmachine-0.12.10/ext/page.cpp +0 -107
  50. data/lib/ext/eventmachine-0.12.10/ext/page.h +0 -51
  51. data/lib/ext/eventmachine-0.12.10/ext/pipe.cpp +0 -349
  52. data/lib/ext/eventmachine-0.12.10/ext/project.h +0 -151
  53. data/lib/ext/eventmachine-0.12.10/ext/rubymain.cpp +0 -1166
  54. data/lib/ext/eventmachine-0.12.10/ext/sigs.cpp +0 -89
  55. data/lib/ext/eventmachine-0.12.10/ext/sigs.h +0 -32
  56. data/lib/ext/eventmachine-0.12.10/ext/ssl.cpp +0 -460
  57. data/lib/ext/eventmachine-0.12.10/ext/ssl.h +0 -94
  58. data/lib/ext/eventmachine-0.12.10/java/.classpath +0 -8
  59. data/lib/ext/eventmachine-0.12.10/java/.project +0 -17
  60. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/EmReactor.java +0 -570
  61. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/EmReactorException.java +0 -40
  62. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/EventableChannel.java +0 -69
  63. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/EventableDatagramChannel.java +0 -189
  64. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/EventableSocketChannel.java +0 -364
  65. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/application/Application.java +0 -194
  66. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/application/Connection.java +0 -74
  67. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/application/ConnectionFactory.java +0 -37
  68. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/application/DefaultConnectionFactory.java +0 -46
  69. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/application/PeriodicTimer.java +0 -38
  70. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/application/Timer.java +0 -54
  71. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/tests/ApplicationTest.java +0 -109
  72. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/tests/ConnectTest.java +0 -148
  73. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/tests/EMTest.java +0 -80
  74. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/tests/TestDatagrams.java +0 -53
  75. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/tests/TestServers.java +0 -75
  76. data/lib/ext/eventmachine-0.12.10/java/src/com/rubyeventmachine/tests/TestTimers.java +0 -90
  77. data/lib/ext/eventmachine-0.12.10/lib/em/buftok.rb +0 -138
  78. data/lib/ext/eventmachine-0.12.10/lib/em/callback.rb +0 -26
  79. data/lib/ext/eventmachine-0.12.10/lib/em/channel.rb +0 -57
  80. data/lib/ext/eventmachine-0.12.10/lib/em/connection.rb +0 -564
  81. data/lib/ext/eventmachine-0.12.10/lib/em/deferrable.rb +0 -192
  82. data/lib/ext/eventmachine-0.12.10/lib/em/file_watch.rb +0 -54
  83. data/lib/ext/eventmachine-0.12.10/lib/em/future.rb +0 -61
  84. data/lib/ext/eventmachine-0.12.10/lib/em/messages.rb +0 -66
  85. data/lib/ext/eventmachine-0.12.10/lib/em/process_watch.rb +0 -44
  86. data/lib/ext/eventmachine-0.12.10/lib/em/processes.rb +0 -119
  87. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/header_and_content.rb +0 -138
  88. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/httpclient.rb +0 -263
  89. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/httpclient2.rb +0 -590
  90. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/line_and_text.rb +0 -125
  91. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/linetext2.rb +0 -161
  92. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/memcache.rb +0 -323
  93. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/object_protocol.rb +0 -45
  94. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/postgres3.rb +0 -247
  95. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/saslauth.rb +0 -175
  96. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/smtpclient.rb +0 -357
  97. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/smtpserver.rb +0 -547
  98. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/socks4.rb +0 -66
  99. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/stomp.rb +0 -200
  100. data/lib/ext/eventmachine-0.12.10/lib/em/protocols/tcptest.rb +0 -53
  101. data/lib/ext/eventmachine-0.12.10/lib/em/protocols.rb +0 -36
  102. data/lib/ext/eventmachine-0.12.10/lib/em/queue.rb +0 -61
  103. data/lib/ext/eventmachine-0.12.10/lib/em/spawnable.rb +0 -85
  104. data/lib/ext/eventmachine-0.12.10/lib/em/streamer.rb +0 -130
  105. data/lib/ext/eventmachine-0.12.10/lib/em/timers.rb +0 -56
  106. data/lib/ext/eventmachine-0.12.10/lib/em/version.rb +0 -3
  107. data/lib/ext/eventmachine-0.12.10/lib/eventmachine.rb +0 -1592
  108. data/lib/ext/eventmachine-0.12.10/lib/evma/callback.rb +0 -32
  109. data/lib/ext/eventmachine-0.12.10/lib/evma/container.rb +0 -75
  110. data/lib/ext/eventmachine-0.12.10/lib/evma/factory.rb +0 -77
  111. data/lib/ext/eventmachine-0.12.10/lib/evma/protocol.rb +0 -87
  112. data/lib/ext/eventmachine-0.12.10/lib/evma/reactor.rb +0 -48
  113. data/lib/ext/eventmachine-0.12.10/lib/evma.rb +0 -32
  114. data/lib/ext/eventmachine-0.12.10/lib/jeventmachine.rb +0 -257
  115. data/lib/ext/eventmachine-0.12.10/lib/pr_eventmachine.rb +0 -1022
  116. data/lib/ext/eventmachine-0.12.10/setup.rb +0 -1585
  117. data/lib/ext/eventmachine-0.12.10/tasks/cpp.rake_example +0 -77
  118. data/lib/ext/eventmachine-0.12.10/tests/client.crt +0 -31
  119. data/lib/ext/eventmachine-0.12.10/tests/client.key +0 -51
  120. data/lib/ext/eventmachine-0.12.10/tests/test_attach.rb +0 -126
  121. data/lib/ext/eventmachine-0.12.10/tests/test_basic.rb +0 -284
  122. data/lib/ext/eventmachine-0.12.10/tests/test_channel.rb +0 -63
  123. data/lib/ext/eventmachine-0.12.10/tests/test_connection_count.rb +0 -35
  124. data/lib/ext/eventmachine-0.12.10/tests/test_defer.rb +0 -47
  125. data/lib/ext/eventmachine-0.12.10/tests/test_epoll.rb +0 -160
  126. data/lib/ext/eventmachine-0.12.10/tests/test_error_handler.rb +0 -35
  127. data/lib/ext/eventmachine-0.12.10/tests/test_errors.rb +0 -82
  128. data/lib/ext/eventmachine-0.12.10/tests/test_exc.rb +0 -55
  129. data/lib/ext/eventmachine-0.12.10/tests/test_file_watch.rb +0 -49
  130. data/lib/ext/eventmachine-0.12.10/tests/test_futures.rb +0 -198
  131. data/lib/ext/eventmachine-0.12.10/tests/test_get_sock_opt.rb +0 -30
  132. data/lib/ext/eventmachine-0.12.10/tests/test_handler_check.rb +0 -37
  133. data/lib/ext/eventmachine-0.12.10/tests/test_hc.rb +0 -218
  134. data/lib/ext/eventmachine-0.12.10/tests/test_httpclient.rb +0 -218
  135. data/lib/ext/eventmachine-0.12.10/tests/test_httpclient2.rb +0 -153
  136. data/lib/ext/eventmachine-0.12.10/tests/test_inactivity_timeout.rb +0 -50
  137. data/lib/ext/eventmachine-0.12.10/tests/test_kb.rb +0 -60
  138. data/lib/ext/eventmachine-0.12.10/tests/test_ltp.rb +0 -182
  139. data/lib/ext/eventmachine-0.12.10/tests/test_ltp2.rb +0 -317
  140. data/lib/ext/eventmachine-0.12.10/tests/test_next_tick.rb +0 -133
  141. data/lib/ext/eventmachine-0.12.10/tests/test_object_protocol.rb +0 -37
  142. data/lib/ext/eventmachine-0.12.10/tests/test_pause.rb +0 -70
  143. data/lib/ext/eventmachine-0.12.10/tests/test_pending_connect_timeout.rb +0 -48
  144. data/lib/ext/eventmachine-0.12.10/tests/test_process_watch.rb +0 -48
  145. data/lib/ext/eventmachine-0.12.10/tests/test_processes.rb +0 -128
  146. data/lib/ext/eventmachine-0.12.10/tests/test_proxy_connection.rb +0 -92
  147. data/lib/ext/eventmachine-0.12.10/tests/test_pure.rb +0 -125
  148. data/lib/ext/eventmachine-0.12.10/tests/test_queue.rb +0 -44
  149. data/lib/ext/eventmachine-0.12.10/tests/test_running.rb +0 -42
  150. data/lib/ext/eventmachine-0.12.10/tests/test_sasl.rb +0 -72
  151. data/lib/ext/eventmachine-0.12.10/tests/test_send_file.rb +0 -242
  152. data/lib/ext/eventmachine-0.12.10/tests/test_servers.rb +0 -76
  153. data/lib/ext/eventmachine-0.12.10/tests/test_smtpclient.rb +0 -83
  154. data/lib/ext/eventmachine-0.12.10/tests/test_smtpserver.rb +0 -85
  155. data/lib/ext/eventmachine-0.12.10/tests/test_spawn.rb +0 -322
  156. data/lib/ext/eventmachine-0.12.10/tests/test_ssl_args.rb +0 -79
  157. data/lib/ext/eventmachine-0.12.10/tests/test_ssl_methods.rb +0 -50
  158. data/lib/ext/eventmachine-0.12.10/tests/test_ssl_verify.rb +0 -82
  159. data/lib/ext/eventmachine-0.12.10/tests/test_timers.rb +0 -162
  160. data/lib/ext/eventmachine-0.12.10/tests/test_ud.rb +0 -36
  161. data/lib/ext/eventmachine-0.12.10/tests/testem.rb +0 -31
  162. data/lib/ext/eventmachine-0.12.10/web/whatis +0 -7
@@ -1,89 +0,0 @@
1
- /*****************************************************************************
2
-
3
- $Id$
4
-
5
- File: sigs.cpp
6
- Date: 06Apr06
7
-
8
- Copyright (C) 2006-07 by Francis Cianfrocca. All Rights Reserved.
9
- Gmail: blackhedd
10
-
11
- This program is free software; you can redistribute it and/or modify
12
- it under the terms of either: 1) the GNU General Public License
13
- as published by the Free Software Foundation; either version 2 of the
14
- License, or (at your option) any later version; or 2) Ruby's License.
15
-
16
- See the file COPYING for complete licensing information.
17
-
18
- *****************************************************************************/
19
-
20
- #include "project.h"
21
-
22
-
23
- bool gTerminateSignalReceived;
24
-
25
-
26
- /**************
27
- SigtermHandler
28
- **************/
29
-
30
- void SigtermHandler (int sig)
31
- {
32
- // This is a signal-handler, don't do anything frisky. Interrupts are disabled.
33
- // Set the terminate flag WITHOUT trying to lock a mutex- otherwise we can easily
34
- // self-deadlock, especially if the event machine is looping quickly.
35
- gTerminateSignalReceived = true;
36
- }
37
-
38
-
39
- /*********************
40
- InstallSignalHandlers
41
- *********************/
42
-
43
- void InstallSignalHandlers()
44
- {
45
- #ifdef OS_UNIX
46
- static bool bInstalled = false;
47
- if (!bInstalled) {
48
- bInstalled = true;
49
- signal (SIGINT, SigtermHandler);
50
- signal (SIGTERM, SigtermHandler);
51
- signal (SIGPIPE, SIG_IGN);
52
- }
53
- #endif
54
- }
55
-
56
-
57
-
58
- /*******************
59
- WintelSignalHandler
60
- *******************/
61
-
62
- #ifdef OS_WIN32
63
- BOOL WINAPI WintelSignalHandler (DWORD control)
64
- {
65
- if (control == CTRL_C_EVENT)
66
- gTerminateSignalReceived = true;
67
- return TRUE;
68
- }
69
- #endif
70
-
71
- /************
72
- HookControlC
73
- ************/
74
-
75
- #ifdef OS_WIN32
76
- void HookControlC (bool hook)
77
- {
78
- if (hook) {
79
- // INSTALL hook
80
- SetConsoleCtrlHandler (WintelSignalHandler, TRUE);
81
- }
82
- else {
83
- // UNINSTALL hook
84
- SetConsoleCtrlHandler (WintelSignalHandler, FALSE);
85
- }
86
- }
87
- #endif
88
-
89
-
@@ -1,32 +0,0 @@
1
- /*****************************************************************************
2
-
3
- $Id$
4
-
5
- File: sigs.h
6
- Date: 06Apr06
7
-
8
- Copyright (C) 2006-07 by Francis Cianfrocca. All Rights Reserved.
9
- Gmail: blackhedd
10
-
11
- This program is free software; you can redistribute it and/or modify
12
- it under the terms of either: 1) the GNU General Public License
13
- as published by the Free Software Foundation; either version 2 of the
14
- License, or (at your option) any later version; or 2) Ruby's License.
15
-
16
- See the file COPYING for complete licensing information.
17
-
18
- *****************************************************************************/
19
-
20
-
21
- #ifndef __Signals__H_
22
- #define __Signals__H_
23
-
24
- void InstallSignalHandlers();
25
- extern bool gTerminateSignalReceived;
26
-
27
- #ifdef OS_WIN32
28
- void HookControlC (bool);
29
- #endif
30
-
31
- #endif // __Signals__H_
32
-
@@ -1,460 +0,0 @@
1
- /*****************************************************************************
2
-
3
- $Id$
4
-
5
- File: ssl.cpp
6
- Date: 30Apr06
7
-
8
- Copyright (C) 2006-07 by Francis Cianfrocca. All Rights Reserved.
9
- Gmail: blackhedd
10
-
11
- This program is free software; you can redistribute it and/or modify
12
- it under the terms of either: 1) the GNU General Public License
13
- as published by the Free Software Foundation; either version 2 of the
14
- License, or (at your option) any later version; or 2) Ruby's License.
15
-
16
- See the file COPYING for complete licensing information.
17
-
18
- *****************************************************************************/
19
-
20
-
21
- #ifdef WITH_SSL
22
-
23
- #include "project.h"
24
-
25
-
26
- bool SslContext_t::bLibraryInitialized = false;
27
-
28
-
29
-
30
- static void InitializeDefaultCredentials();
31
- static EVP_PKEY *DefaultPrivateKey = NULL;
32
- static X509 *DefaultCertificate = NULL;
33
-
34
- static char PrivateMaterials[] = {
35
- "-----BEGIN RSA PRIVATE KEY-----\n"
36
- "MIICXAIBAAKBgQDCYYhcw6cGRbhBVShKmbWm7UVsEoBnUf0cCh8AX+MKhMxwVDWV\n"
37
- "Igdskntn3cSJjRtmgVJHIK0lpb/FYHQB93Ohpd9/Z18pDmovfFF9nDbFF0t39hJ/\n"
38
- "AqSzFB3GiVPoFFZJEE1vJqh+3jzsSF5K56bZ6azz38VlZgXeSozNW5bXkQIDAQAB\n"
39
- "AoGALA89gIFcr6BIBo8N5fL3aNHpZXjAICtGav+kTUpuxSiaym9cAeTHuAVv8Xgk\n"
40
- "H2Wbq11uz+6JMLpkQJH/WZ7EV59DPOicXrp0Imr73F3EXBfR7t2EQDYHPMthOA1D\n"
41
- "I9EtCzvV608Ze90hiJ7E3guGrGppZfJ+eUWCPgy8CZH1vRECQQDv67rwV/oU1aDo\n"
42
- "6/+d5nqjeW6mWkGqTnUU96jXap8EIw6B+0cUKskwx6mHJv+tEMM2748ZY7b0yBlg\n"
43
- "w4KDghbFAkEAz2h8PjSJG55LwqmXih1RONSgdN9hjB12LwXL1CaDh7/lkEhq0PlK\n"
44
- "PCAUwQSdM17Sl0Xxm2CZiekTSlwmHrtqXQJAF3+8QJwtV2sRJp8u2zVe37IeH1cJ\n"
45
- "xXeHyjTzqZ2803fnjN2iuZvzNr7noOA1/Kp+pFvUZUU5/0G2Ep8zolPUjQJAFA7k\n"
46
- "xRdLkzIx3XeNQjwnmLlncyYPRv+qaE3FMpUu7zftuZBnVCJnvXzUxP3vPgKTlzGa\n"
47
- "dg5XivDRfsV+okY5uQJBAMV4FesUuLQVEKb6lMs7rzZwpeGQhFDRfywJzfom2TLn\n"
48
- "2RdJQQ3dcgnhdVDgt5o1qkmsqQh8uJrJ9SdyLIaZQIc=\n"
49
- "-----END RSA PRIVATE KEY-----\n"
50
- "-----BEGIN CERTIFICATE-----\n"
51
- "MIID6TCCA1KgAwIBAgIJANm4W/Tzs+s+MA0GCSqGSIb3DQEBBQUAMIGqMQswCQYD\n"
52
- "VQQGEwJVUzERMA8GA1UECBMITmV3IFlvcmsxETAPBgNVBAcTCE5ldyBZb3JrMRYw\n"
53
- "FAYDVQQKEw1TdGVhbWhlYXQubmV0MRQwEgYDVQQLEwtFbmdpbmVlcmluZzEdMBsG\n"
54
- "A1UEAxMUb3BlbmNhLnN0ZWFtaGVhdC5uZXQxKDAmBgkqhkiG9w0BCQEWGWVuZ2lu\n"
55
- "ZWVyaW5nQHN0ZWFtaGVhdC5uZXQwHhcNMDYwNTA1MTcwNjAzWhcNMjQwMjIwMTcw\n"
56
- "NjAzWjCBqjELMAkGA1UEBhMCVVMxETAPBgNVBAgTCE5ldyBZb3JrMREwDwYDVQQH\n"
57
- "EwhOZXcgWW9yazEWMBQGA1UEChMNU3RlYW1oZWF0Lm5ldDEUMBIGA1UECxMLRW5n\n"
58
- "aW5lZXJpbmcxHTAbBgNVBAMTFG9wZW5jYS5zdGVhbWhlYXQubmV0MSgwJgYJKoZI\n"
59
- "hvcNAQkBFhllbmdpbmVlcmluZ0BzdGVhbWhlYXQubmV0MIGfMA0GCSqGSIb3DQEB\n"
60
- "AQUAA4GNADCBiQKBgQDCYYhcw6cGRbhBVShKmbWm7UVsEoBnUf0cCh8AX+MKhMxw\n"
61
- "VDWVIgdskntn3cSJjRtmgVJHIK0lpb/FYHQB93Ohpd9/Z18pDmovfFF9nDbFF0t3\n"
62
- "9hJ/AqSzFB3GiVPoFFZJEE1vJqh+3jzsSF5K56bZ6azz38VlZgXeSozNW5bXkQID\n"
63
- "AQABo4IBEzCCAQ8wHQYDVR0OBBYEFPJvPd1Fcmd8o/Tm88r+NjYPICCkMIHfBgNV\n"
64
- "HSMEgdcwgdSAFPJvPd1Fcmd8o/Tm88r+NjYPICCkoYGwpIGtMIGqMQswCQYDVQQG\n"
65
- "EwJVUzERMA8GA1UECBMITmV3IFlvcmsxETAPBgNVBAcTCE5ldyBZb3JrMRYwFAYD\n"
66
- "VQQKEw1TdGVhbWhlYXQubmV0MRQwEgYDVQQLEwtFbmdpbmVlcmluZzEdMBsGA1UE\n"
67
- "AxMUb3BlbmNhLnN0ZWFtaGVhdC5uZXQxKDAmBgkqhkiG9w0BCQEWGWVuZ2luZWVy\n"
68
- "aW5nQHN0ZWFtaGVhdC5uZXSCCQDZuFv087PrPjAMBgNVHRMEBTADAQH/MA0GCSqG\n"
69
- "SIb3DQEBBQUAA4GBAC1CXey/4UoLgJiwcEMDxOvW74plks23090iziFIlGgcIhk0\n"
70
- "Df6hTAs7H3MWww62ddvR8l07AWfSzSP5L6mDsbvq7EmQsmPODwb6C+i2aF3EDL8j\n"
71
- "uw73m4YIGI0Zw2XdBpiOGkx2H56Kya6mJJe/5XORZedh1wpI7zki01tHYbcy\n"
72
- "-----END CERTIFICATE-----\n"};
73
-
74
- /* These private materials were made with:
75
- * openssl req -new -x509 -keyout cakey.pem -out cacert.pem -nodes -days 6500
76
- * TODO: We need a full-blown capability to work with user-supplied
77
- * keypairs and properly-signed certificates.
78
- */
79
-
80
-
81
- /*****************
82
- builtin_passwd_cb
83
- *****************/
84
-
85
- extern "C" int builtin_passwd_cb (char *buf, int bufsize, int rwflag, void *userdata)
86
- {
87
- strcpy (buf, "kittycat");
88
- return 8;
89
- }
90
-
91
- /****************************
92
- InitializeDefaultCredentials
93
- ****************************/
94
-
95
- static void InitializeDefaultCredentials()
96
- {
97
- BIO *bio = BIO_new_mem_buf (PrivateMaterials, -1);
98
- assert (bio);
99
-
100
- if (DefaultPrivateKey) {
101
- // we may come here in a restart.
102
- EVP_PKEY_free (DefaultPrivateKey);
103
- DefaultPrivateKey = NULL;
104
- }
105
- PEM_read_bio_PrivateKey (bio, &DefaultPrivateKey, builtin_passwd_cb, 0);
106
-
107
- if (DefaultCertificate) {
108
- // we may come here in a restart.
109
- X509_free (DefaultCertificate);
110
- DefaultCertificate = NULL;
111
- }
112
- PEM_read_bio_X509 (bio, &DefaultCertificate, NULL, 0);
113
-
114
- BIO_free (bio);
115
- }
116
-
117
-
118
-
119
- /**************************
120
- SslContext_t::SslContext_t
121
- **************************/
122
-
123
- SslContext_t::SslContext_t (bool is_server, const string &privkeyfile, const string &certchainfile):
124
- pCtx (NULL),
125
- PrivateKey (NULL),
126
- Certificate (NULL)
127
- {
128
- /* TODO: the usage of the specified private-key and cert-chain filenames only applies to
129
- * client-side connections at this point. Server connections currently use the default materials.
130
- * That needs to be fixed asap.
131
- * Also, in this implementation, server-side connections use statically defined X-509 defaults.
132
- * One thing I'm really not clear on is whether or not you have to explicitly free X509 and EVP_PKEY
133
- * objects when we call our destructor, or whether just calling SSL_CTX_free is enough.
134
- */
135
-
136
- if (!bLibraryInitialized) {
137
- bLibraryInitialized = true;
138
- SSL_library_init();
139
- OpenSSL_add_ssl_algorithms();
140
- OpenSSL_add_all_algorithms();
141
- SSL_load_error_strings();
142
- ERR_load_crypto_strings();
143
-
144
- InitializeDefaultCredentials();
145
- }
146
-
147
- bIsServer = is_server;
148
- pCtx = SSL_CTX_new (is_server ? SSLv23_server_method() : SSLv23_client_method());
149
- if (!pCtx)
150
- throw std::runtime_error ("no SSL context");
151
-
152
- SSL_CTX_set_options (pCtx, SSL_OP_ALL);
153
- //SSL_CTX_set_options (pCtx, (SSL_OP_NO_SSLv2 | SSL_OP_NO_SSLv3));
154
-
155
- if (is_server) {
156
- // The SSL_CTX calls here do NOT allocate memory.
157
- int e;
158
- if (privkeyfile.length() > 0)
159
- e = SSL_CTX_use_PrivateKey_file (pCtx, privkeyfile.c_str(), SSL_FILETYPE_PEM);
160
- else
161
- e = SSL_CTX_use_PrivateKey (pCtx, DefaultPrivateKey);
162
- assert (e > 0);
163
- if (certchainfile.length() > 0)
164
- e = SSL_CTX_use_certificate_chain_file (pCtx, certchainfile.c_str());
165
- else
166
- e = SSL_CTX_use_certificate (pCtx, DefaultCertificate);
167
- assert (e > 0);
168
- }
169
-
170
- SSL_CTX_set_cipher_list (pCtx, "ALL:!ADH:!LOW:!EXP:!DES-CBC3-SHA:@STRENGTH");
171
-
172
- if (is_server) {
173
- SSL_CTX_sess_set_cache_size (pCtx, 128);
174
- SSL_CTX_set_session_id_context (pCtx, (unsigned char*)"eventmachine", 12);
175
- }
176
- else {
177
- int e;
178
- if (privkeyfile.length() > 0) {
179
- e = SSL_CTX_use_PrivateKey_file (pCtx, privkeyfile.c_str(), SSL_FILETYPE_PEM);
180
- assert (e > 0);
181
- }
182
- if (certchainfile.length() > 0) {
183
- e = SSL_CTX_use_certificate_chain_file (pCtx, certchainfile.c_str());
184
- assert (e > 0);
185
- }
186
- }
187
- }
188
-
189
-
190
-
191
- /***************************
192
- SslContext_t::~SslContext_t
193
- ***************************/
194
-
195
- SslContext_t::~SslContext_t()
196
- {
197
- if (pCtx)
198
- SSL_CTX_free (pCtx);
199
- if (PrivateKey)
200
- EVP_PKEY_free (PrivateKey);
201
- if (Certificate)
202
- X509_free (Certificate);
203
- }
204
-
205
-
206
-
207
- /******************
208
- SslBox_t::SslBox_t
209
- ******************/
210
-
211
- SslBox_t::SslBox_t (bool is_server, const string &privkeyfile, const string &certchainfile, bool verify_peer, const unsigned long binding):
212
- bIsServer (is_server),
213
- bHandshakeCompleted (false),
214
- bVerifyPeer (verify_peer),
215
- pSSL (NULL),
216
- pbioRead (NULL),
217
- pbioWrite (NULL)
218
- {
219
- /* TODO someday: make it possible to re-use SSL contexts so we don't have to create
220
- * a new one every time we come here.
221
- */
222
-
223
- Context = new SslContext_t (bIsServer, privkeyfile, certchainfile);
224
- assert (Context);
225
-
226
- pbioRead = BIO_new (BIO_s_mem());
227
- assert (pbioRead);
228
-
229
- pbioWrite = BIO_new (BIO_s_mem());
230
- assert (pbioWrite);
231
-
232
- pSSL = SSL_new (Context->pCtx);
233
- assert (pSSL);
234
- SSL_set_bio (pSSL, pbioRead, pbioWrite);
235
-
236
- // Store a pointer to the binding signature in the SSL object so we can retrieve it later
237
- SSL_set_ex_data(pSSL, 0, (void*) binding);
238
-
239
- if (bVerifyPeer)
240
- SSL_set_verify(pSSL, SSL_VERIFY_PEER | SSL_VERIFY_CLIENT_ONCE, ssl_verify_wrapper);
241
-
242
- if (!bIsServer)
243
- SSL_connect (pSSL);
244
- }
245
-
246
-
247
-
248
- /*******************
249
- SslBox_t::~SslBox_t
250
- *******************/
251
-
252
- SslBox_t::~SslBox_t()
253
- {
254
- // Freeing pSSL will also free the associated BIOs, so DON'T free them separately.
255
- if (pSSL) {
256
- if (SSL_get_shutdown (pSSL) & SSL_RECEIVED_SHUTDOWN)
257
- SSL_shutdown (pSSL);
258
- else
259
- SSL_clear (pSSL);
260
- SSL_free (pSSL);
261
- }
262
-
263
- delete Context;
264
- }
265
-
266
-
267
-
268
- /***********************
269
- SslBox_t::PutCiphertext
270
- ***********************/
271
-
272
- bool SslBox_t::PutCiphertext (const char *buf, int bufsize)
273
- {
274
- assert (buf && (bufsize > 0));
275
-
276
- assert (pbioRead);
277
- int n = BIO_write (pbioRead, buf, bufsize);
278
-
279
- return (n == bufsize) ? true : false;
280
- }
281
-
282
-
283
- /**********************
284
- SslBox_t::GetPlaintext
285
- **********************/
286
-
287
- int SslBox_t::GetPlaintext (char *buf, int bufsize)
288
- {
289
- if (!SSL_is_init_finished (pSSL)) {
290
- int e = bIsServer ? SSL_accept (pSSL) : SSL_connect (pSSL);
291
- if (e < 0) {
292
- int er = SSL_get_error (pSSL, e);
293
- if (er != SSL_ERROR_WANT_READ) {
294
- // Return -1 for a nonfatal error, -2 for an error that should force the connection down.
295
- return (er == SSL_ERROR_SSL) ? (-2) : (-1);
296
- }
297
- else
298
- return 0;
299
- }
300
- bHandshakeCompleted = true;
301
- // If handshake finished, FALL THROUGH and return the available plaintext.
302
- }
303
-
304
- if (!SSL_is_init_finished (pSSL)) {
305
- // We can get here if a browser abandons a handshake.
306
- // The user can see a warning dialog and abort the connection.
307
- cerr << "<SSL_incomp>";
308
- return 0;
309
- }
310
-
311
- //cerr << "CIPH: " << SSL_get_cipher (pSSL) << endl;
312
-
313
- int n = SSL_read (pSSL, buf, bufsize);
314
- if (n >= 0) {
315
- return n;
316
- }
317
- else {
318
- if (SSL_get_error (pSSL, n) == SSL_ERROR_WANT_READ) {
319
- return 0;
320
- }
321
- else {
322
- return -1;
323
- }
324
- }
325
-
326
- return 0;
327
- }
328
-
329
-
330
-
331
- /**************************
332
- SslBox_t::CanGetCiphertext
333
- **************************/
334
-
335
- bool SslBox_t::CanGetCiphertext()
336
- {
337
- assert (pbioWrite);
338
- return BIO_pending (pbioWrite) ? true : false;
339
- }
340
-
341
-
342
-
343
- /***********************
344
- SslBox_t::GetCiphertext
345
- ***********************/
346
-
347
- int SslBox_t::GetCiphertext (char *buf, int bufsize)
348
- {
349
- assert (pbioWrite);
350
- assert (buf && (bufsize > 0));
351
-
352
- return BIO_read (pbioWrite, buf, bufsize);
353
- }
354
-
355
-
356
-
357
- /**********************
358
- SslBox_t::PutPlaintext
359
- **********************/
360
-
361
- int SslBox_t::PutPlaintext (const char *buf, int bufsize)
362
- {
363
- // The caller will interpret the return value as the number of bytes written.
364
- // WARNING WARNING WARNING, are there any situations in which a 0 or -1 return
365
- // from SSL_write means we should immediately retry? The socket-machine loop
366
- // will probably wait for a time-out cycle (perhaps a second) before re-trying.
367
- // THIS WOULD CAUSE A PERCEPTIBLE DELAY!
368
-
369
- /* We internally queue any outbound plaintext that can't be dispatched
370
- * because we're in the middle of a handshake or something.
371
- * When we get called, try to send any queued data first, and then
372
- * send the caller's data (or queue it). We may get called with no outbound
373
- * data, which means we try to send the outbound queue and that's all.
374
- *
375
- * Return >0 if we wrote any data, 0 if we didn't, and <0 for a fatal error.
376
- * Note that if we return 0, the connection is still considered live
377
- * and we are signalling that we have accepted the outbound data (if any).
378
- */
379
-
380
- OutboundQ.Push (buf, bufsize);
381
-
382
- if (!SSL_is_init_finished (pSSL))
383
- return 0;
384
-
385
- bool fatal = false;
386
- bool did_work = false;
387
-
388
- while (OutboundQ.HasPages()) {
389
- const char *page;
390
- int length;
391
- OutboundQ.Front (&page, &length);
392
- assert (page && (length > 0));
393
- int n = SSL_write (pSSL, page, length);
394
- if (n > 0) {
395
- did_work = true;
396
- OutboundQ.PopFront();
397
- }
398
- else {
399
- int er = SSL_get_error (pSSL, n);
400
- if ((er != SSL_ERROR_WANT_READ) && (er != SSL_ERROR_WANT_WRITE))
401
- fatal = true;
402
- break;
403
- }
404
- }
405
-
406
-
407
- if (did_work)
408
- return 1;
409
- else if (fatal)
410
- return -1;
411
- else
412
- return 0;
413
- }
414
-
415
- /**********************
416
- SslBox_t::GetPeerCert
417
- **********************/
418
-
419
- X509 *SslBox_t::GetPeerCert()
420
- {
421
- X509 *cert = NULL;
422
-
423
- if (pSSL)
424
- cert = SSL_get_peer_certificate(pSSL);
425
-
426
- return cert;
427
- }
428
-
429
-
430
- /******************
431
- ssl_verify_wrapper
432
- *******************/
433
-
434
- extern "C" int ssl_verify_wrapper(int preverify_ok, X509_STORE_CTX *ctx)
435
- {
436
- unsigned long binding;
437
- X509 *cert;
438
- SSL *ssl;
439
- BUF_MEM *buf;
440
- BIO *out;
441
- int result;
442
-
443
- cert = X509_STORE_CTX_get_current_cert(ctx);
444
- ssl = (SSL*) X509_STORE_CTX_get_ex_data(ctx, SSL_get_ex_data_X509_STORE_CTX_idx());
445
- binding = (unsigned long) SSL_get_ex_data(ssl, 0);
446
-
447
- out = BIO_new(BIO_s_mem());
448
- PEM_write_bio_X509(out, cert);
449
- BIO_write(out, "\0", 1);
450
- BIO_get_mem_ptr(out, &buf);
451
-
452
- ConnectionDescriptor *cd = dynamic_cast <ConnectionDescriptor*> (Bindable_t::GetObject(binding));
453
- result = (cd->VerifySslPeer(buf->data) == true ? 1 : 0);
454
- BUF_MEM_free(buf);
455
-
456
- return result;
457
- }
458
-
459
- #endif // WITH_SSL
460
-
@@ -1,94 +0,0 @@
1
- /*****************************************************************************
2
-
3
- $Id$
4
-
5
- File: ssl.h
6
- Date: 30Apr06
7
-
8
- Copyright (C) 2006-07 by Francis Cianfrocca. All Rights Reserved.
9
- Gmail: blackhedd
10
-
11
- This program is free software; you can redistribute it and/or modify
12
- it under the terms of either: 1) the GNU General Public License
13
- as published by the Free Software Foundation; either version 2 of the
14
- License, or (at your option) any later version; or 2) Ruby's License.
15
-
16
- See the file COPYING for complete licensing information.
17
-
18
- *****************************************************************************/
19
-
20
-
21
- #ifndef __SslBox__H_
22
- #define __SslBox__H_
23
-
24
-
25
-
26
-
27
- #ifdef WITH_SSL
28
-
29
- /******************
30
- class SslContext_t
31
- ******************/
32
-
33
- class SslContext_t
34
- {
35
- public:
36
- SslContext_t (bool is_server, const string &privkeyfile, const string &certchainfile);
37
- virtual ~SslContext_t();
38
-
39
- private:
40
- static bool bLibraryInitialized;
41
-
42
- private:
43
- bool bIsServer;
44
- SSL_CTX *pCtx;
45
-
46
- EVP_PKEY *PrivateKey;
47
- X509 *Certificate;
48
-
49
- friend class SslBox_t;
50
- };
51
-
52
-
53
- /**************
54
- class SslBox_t
55
- **************/
56
-
57
- class SslBox_t
58
- {
59
- public:
60
- SslBox_t (bool is_server, const string &privkeyfile, const string &certchainfile, bool verify_peer, const unsigned long binding);
61
- virtual ~SslBox_t();
62
-
63
- int PutPlaintext (const char*, int);
64
- int GetPlaintext (char*, int);
65
-
66
- bool PutCiphertext (const char*, int);
67
- bool CanGetCiphertext();
68
- int GetCiphertext (char*, int);
69
- bool IsHandshakeCompleted() {return bHandshakeCompleted;}
70
-
71
- X509 *GetPeerCert();
72
-
73
- void Shutdown();
74
-
75
- protected:
76
- SslContext_t *Context;
77
-
78
- bool bIsServer;
79
- bool bHandshakeCompleted;
80
- bool bVerifyPeer;
81
- SSL *pSSL;
82
- BIO *pbioRead;
83
- BIO *pbioWrite;
84
-
85
- PageList OutboundQ;
86
- };
87
-
88
- extern "C" int ssl_verify_wrapper(int, X509_STORE_CTX*);
89
-
90
- #endif // WITH_SSL
91
-
92
-
93
- #endif // __SslBox__H_
94
-
@@ -1,8 +0,0 @@
1
- <?xml version="1.0" encoding="UTF-8"?>
2
- <classpath>
3
- <classpathentry kind="src" path="src"/>
4
- <classpathentry excluding="src/" kind="src" path=""/>
5
- <classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
6
- <classpathentry kind="con" path="org.eclipse.jdt.junit.JUNIT_CONTAINER/4"/>
7
- <classpathentry kind="output" path="src"/>
8
- </classpath>
@@ -1,17 +0,0 @@
1
- <?xml version="1.0" encoding="UTF-8"?>
2
- <projectDescription>
3
- <name>em_reactor</name>
4
- <comment></comment>
5
- <projects>
6
- </projects>
7
- <buildSpec>
8
- <buildCommand>
9
- <name>org.eclipse.jdt.core.javabuilder</name>
10
- <arguments>
11
- </arguments>
12
- </buildCommand>
13
- </buildSpec>
14
- <natures>
15
- <nature>org.eclipse.jdt.core.javanature</nature>
16
- </natures>
17
- </projectDescription>