rhodes 7.4.1 → 7.6.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (305) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG +319 -0
  3. data/CREDITS +3 -1
  4. data/LICENSE +1 -1
  5. data/README.md +6 -16
  6. data/Rakefile +55 -43
  7. data/SECURITY.md +19 -0
  8. data/appveyor.yml +66 -8
  9. data/azure-pipelines.yml +67 -0
  10. data/bin/rhodes-setup +22 -8
  11. data/extensions/emdk3-manager/ext/platform/android/src/com/rho/emdk3/EMDK3Extension.java +14 -5
  12. data/extensions/instrumentation/ext/platform/android/src/com/rho/instrumentation/Instrumentation.java +29 -15
  13. data/extensions/rhoconnect-push/ext/rhoconnect-push/platform/android/src/com/rhomobile/rhoelements/ans/ANSManager.java +3 -3
  14. data/extensions/rhoelementsext/ext/rhoelementsext/platform/android/rhoelements_temp/src/com/rho/rhoelements/ElementsCore.java +12 -9
  15. data/extensions/rhoelementsext/ext/rhoelementsext/platform/android/rhoelements_temp/src/com/rho/rhoelements/graphics/BatteryIndicator.java +2 -2
  16. data/lib/commonAPI/barcode/ext/platform/android/AndroidManifest.xml +3 -1
  17. data/lib/commonAPI/barcode/ext/platform/android/src/com/google/barcodereader/BarcodeCaptureActivity.java +11 -13
  18. data/lib/commonAPI/barcode/ext/platform/android/src/com/google/barcodereader/BarcodeGraphicTracker.java +1 -1
  19. data/lib/commonAPI/barcode/ext/platform/android/src/com/google/barcodereader/ui/camera/CameraSource.java +3 -3
  20. data/lib/commonAPI/barcode/ext/platform/android/src/com/google/barcodereader/ui/camera/CameraSourcePreview.java +1 -1
  21. data/lib/commonAPI/barcode/ext/platform/qt/Barcode.pro +1 -1
  22. data/lib/commonAPI/barcode/ext/platform/qt/Barcode.pro.erb +2 -2
  23. data/lib/commonAPI/barcode/ext/platform/qt/src/qzxing/QZXing.pri +9 -21
  24. data/lib/commonAPI/barcode/ext.yml +5 -8
  25. data/lib/commonAPI/bluetooth/ext/platform/qt/Bluetooth.pro +1 -1
  26. data/lib/commonAPI/bluetooth/ext/platform/qt/Bluetooth.pro.erb +1 -1
  27. data/lib/commonAPI/bluetooth/ext/platform/qt/src/bluetooth/bluetoothhelper.h +1 -1
  28. data/lib/commonAPI/coreapi/RhoSystemApi.rb +6 -0
  29. data/lib/commonAPI/coreapi/ext/Intent.xml +4 -0
  30. data/lib/commonAPI/coreapi/ext/platform/android/Rakefile +0 -12
  31. data/lib/commonAPI/coreapi/ext/platform/android/src/com/rho/intent/IntentSingleton.java +6 -0
  32. data/lib/commonAPI/coreapi/ext/platform/android/src/com/rho/notification/Notification.java +5 -2
  33. data/lib/commonAPI/coreapi/ext/platform/android/src/com/rho/notification/NotificationScheduler.java +4 -4
  34. data/lib/commonAPI/coreapi/ext/platform/android/src/com/rho/notification/NotificationSingleton.java +1 -1
  35. data/lib/commonAPI/coreapi/ext/platform/android/src/com/rho/webview/WebViewSingleton.java +40 -27
  36. data/lib/commonAPI/coreapi/ext/platform/iphone/cpp_based_impl/SystemImpl.mm +5 -6
  37. data/lib/commonAPI/coreapi/ext/platform/iphone/impl/Intent.h +1 -1
  38. data/lib/commonAPI/coreapi/ext/platform/iphone/impl/Intent.m +3 -1
  39. data/lib/commonAPI/coreapi/ext/platform/iphone/impl/NotificationSingleton.h +2 -1
  40. data/lib/commonAPI/coreapi/ext/platform/iphone/impl/NotificationSingleton.m +10 -0
  41. data/lib/commonAPI/coreapi/ext/platform/wm/src/IntentImpl.cpp +3 -0
  42. data/lib/commonAPI/coreapi/ext/push.xml +5 -2
  43. data/lib/commonAPI/coreapi/ext/shared/SystemImplBase.cpp +13 -0
  44. data/lib/commonAPI/coreapi/ext/shared/SystemImplBase.h +2 -0
  45. data/lib/commonAPI/coreapi/ext/system.xml +3 -0
  46. data/lib/commonAPI/mediacapture/ext/camera.xml +4 -9
  47. data/lib/commonAPI/mediacapture/ext/platform/android/ApplicationCameraActivity.erb +2 -2
  48. data/lib/commonAPI/mediacapture/ext/platform/android/ApplicationFileProvider.erb +1 -1
  49. data/lib/commonAPI/mediacapture/ext/platform/android/ext_java.files +2 -9
  50. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/CameraExtension.java +0 -2
  51. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/CameraFactory.java +19 -24
  52. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/CameraObject.java +322 -730
  53. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/CameraRhoListener.java +247 -433
  54. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/{CameraSingletonObject.java → CameraSingleton.java} +68 -74
  55. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/mediacapture/RhoCameraFileProvider.java +6 -0
  56. data/lib/commonAPI/mediacapture/ext/platform/qt/MediaCapture.pro.erb +1 -1
  57. data/lib/commonAPI/mediacapture/ext/platform/qt/Mediacapture.pro +1 -1
  58. data/lib/commonAPI/printing_zebra/ext/platform/android/src/com/rhomobile/printing/zebra/impl/ZebraPrintingProviderImpl.java +2 -1
  59. data/lib/commonAPI/signature/ext/platform/iphone/impl/readme.txt +7 -0
  60. data/lib/commonAPI/signature/ext/platform/qt/Signature.pro +3 -10
  61. data/lib/commonAPI/signature/ext/platform/qt/Signature.pro.erb +2 -2
  62. data/lib/extensions/fcm-push/ext/android/ApplicationManifestAdds.erb +15 -17
  63. data/lib/extensions/fcm-push/ext/android/Rakefile +59 -34
  64. data/lib/extensions/fcm-push/ext/android/ext_java.files +0 -1
  65. data/lib/extensions/fcm-push/ext/android/src/com/rhomobile/rhodes/fcm/FCMFacade.java +13 -17
  66. data/lib/extensions/fcm-push/ext/android/src/com/rhomobile/rhodes/fcm/FCMIntentService.java +81 -80
  67. data/lib/extensions/fcm-push/ext/android/src/com/rhomobile/rhodes/fcm/FCMListener.java +0 -16
  68. data/lib/extensions/fcm-push/ext/iphone/Podfile +15 -2
  69. data/lib/extensions/fcm-push/ext/iphone/fcm-push.xcodeproj/project.pbxproj +6 -7
  70. data/lib/extensions/fcm-push/ext.yml +1 -1
  71. data/lib/extensions/gmaps/ext/platform/android/ApplicationManifestAdds.erb +1 -0
  72. data/lib/extensions/gmaps/ext/platform/android/src/com/rhomobile/rhodes/gmaps/GMapActivity.java +12 -4
  73. data/lib/extensions/gmaps/ext.yml +3 -1
  74. data/lib/extensions/nfc/ext/platform/android/src/com/rhomobile/nfc/Nfc.java +2 -1
  75. data/lib/extensions/serialport/ext/serialport.pro +1 -1
  76. data/platform/android/Rhodes/jni/include/rhodes/JNIRhodes.h +1 -0
  77. data/platform/android/Rhodes/jni/src/MethodResultJni.cpp +4 -0
  78. data/platform/android/Rhodes/jni/src/fileapi.cpp +4 -0
  79. data/platform/android/Rhodes/res/drawable/baseline_check_24.xml +5 -0
  80. data/platform/android/Rhodes/res/drawable/baseline_check_240.xml +5 -0
  81. data/platform/android/Rhodes/res/drawable/baseline_close_24.xml +5 -0
  82. data/platform/android/Rhodes/res/drawable/baseline_close_240.xml +5 -0
  83. data/platform/android/Rhodes/res/layout/overlay_layout.xml +39 -0
  84. data/platform/android/Rhodes/res/layout/perrmission_alert_dialog.xml +267 -0
  85. data/platform/android/Rhodes/src/com/rhomobile/rhodes/BaseActivity.java +183 -66
  86. data/platform/android/Rhodes/src/com/rhomobile/rhodes/LocalFileProvider.java +38 -6
  87. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhoFileProvider.java +32 -0
  88. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesActivity.java +532 -92
  89. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesApplication.java +26 -4
  90. data/platform/android/Rhodes/src/com/rhomobile/rhodes/RhodesService.java +259 -163
  91. data/platform/android/Rhodes/src/com/rhomobile/rhodes/alert/StatusNotification.java +1 -1
  92. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/AbstractRhoExtension.java +14 -3
  93. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtManager.java +4 -0
  94. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/IRhoExtension.java +5 -4
  95. data/platform/android/Rhodes/src/com/rhomobile/rhodes/extmanager/RhoExtManagerImpl.java +79 -38
  96. data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocation.java +20 -15
  97. data/platform/android/Rhodes/src/com/rhomobile/rhodes/geolocation/GeoLocationImpl.java +18 -9
  98. data/platform/android/Rhodes/src/com/rhomobile/rhodes/kioskservices/CallReceiver.java +22 -0
  99. data/platform/android/Rhodes/src/com/rhomobile/rhodes/kioskservices/IKioskMode.java +11 -0
  100. data/platform/android/Rhodes/src/com/rhomobile/rhodes/kioskservices/KioskManager.java +18 -0
  101. data/platform/android/Rhodes/src/com/rhomobile/rhodes/kioskservices/MyAccessibilityService.java +230 -0
  102. data/platform/android/Rhodes/src/com/rhomobile/rhodes/kioskservices/MyNotificationListenerService.java +16 -0
  103. data/platform/android/Rhodes/src/com/rhomobile/rhodes/kioskservices/MyOverlayService.java +197 -0
  104. data/platform/android/Rhodes/src/com/rhomobile/rhodes/kioskservices/PermissionManager.java +232 -0
  105. data/platform/android/Rhodes/src/com/rhomobile/rhodes/mainview/SimpleMainView.java +34 -8
  106. data/platform/android/Rhodes/src/com/rhomobile/rhodes/osfunctionality/AndroidFunctionality26.java +1 -1
  107. data/platform/android/Rhodes/src/com/rhomobile/rhodes/permissioncheck/CheckDrawable.java +53 -0
  108. data/platform/android/Rhodes/src/com/rhomobile/rhodes/permissioncheck/PermissionListGenerate.java +366 -0
  109. data/platform/android/Rhodes/src/com/rhomobile/rhodes/rhodes.iml +11 -0
  110. data/platform/android/Rhodes/src/com/rhomobile/rhodes/socket/SSLImpl.java +1 -0
  111. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/GoogleWebView.java +782 -41
  112. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoInputConnectionWrapper.java +146 -0
  113. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoInputListener.java +21 -0
  114. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/RhoWebViewClient.java +92 -32
  115. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/TauWebViewOptions.java +118 -0
  116. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/WebSettingsProviderBase.java +18 -17
  117. data/platform/android/Rhodes/src/com/rhomobile/rhodes/webview/WebSettingsProviderEclairMR1.java +4 -4
  118. data/platform/android/build/RhodesSRC_build.files +13 -0
  119. data/platform/android/build/{aab_builder.rb → aapt2_helper.rb} +94 -37
  120. data/platform/android/build/android-repack.rake +8 -1
  121. data/platform/android/build/android.rake +238 -238
  122. data/platform/android/build/android_tools.rb +10 -10
  123. data/platform/android/build/androidcommon.rb +31 -14
  124. data/platform/android/build/build_tools_finder.rb +46 -0
  125. data/platform/android/build/config.yml +8 -0
  126. data/platform/android/build/dex_builder.rb +88 -0
  127. data/platform/android/build/hostplatform.rb +9 -0
  128. data/platform/android/build/manifest_generator.rb +15 -10
  129. data/platform/android/build/maven_deps_extractor.rb +29 -22
  130. data/platform/android/build/ndkwrapper.rb +92 -51
  131. data/platform/android/proguard/proguard-base-rules.pro +5 -0
  132. data/platform/android/proguard/proguard.jar +0 -0
  133. data/platform/iphone/Classes/AppManager/AppManager.m +3 -1
  134. data/platform/iphone/Classes/Camera/PickImageDelegate.h +2 -0
  135. data/platform/iphone/Classes/Camera/PickImageDelegate.m +45 -23
  136. data/platform/iphone/Classes/CocoaServer/CCocoaServer.h +27 -0
  137. data/platform/iphone/Classes/CocoaServer/CCocoaServer.m +107 -0
  138. data/platform/iphone/Classes/CocoaServer/RhoHTTPConnection.h +16 -0
  139. data/platform/iphone/Classes/CocoaServer/RhoHTTPConnection.m +226 -0
  140. data/platform/iphone/Classes/RhoAppBaseLib-Bridging-Header.h +4 -0
  141. data/platform/iphone/Classes/RhoAppBaseStandaloneLib-Bridging-Header.h +4 -0
  142. data/platform/iphone/Classes/RhoCryptAESGCM.swift +105 -0
  143. data/platform/iphone/Classes/RhoUIWebView.h +1 -1
  144. data/platform/iphone/Classes/RhoUIWebView.m +1 -1
  145. data/platform/iphone/Classes/RhoWKWebView.h +1 -1
  146. data/platform/iphone/Classes/RhoWKWebView.mm +110 -15
  147. data/platform/iphone/Classes/RhoWebView.h +1 -1
  148. data/platform/iphone/Classes/RhoWebViewFabrique.m +13 -2
  149. data/platform/iphone/Classes/Rhodes.m +3 -0
  150. data/platform/iphone/Classes/SimpleMainView.m +5 -5
  151. data/platform/iphone/Classes/URLProtocol/CRhoURLProtocol.m +21 -10
  152. data/platform/iphone/Classes/rho/net/IPhoneNetRequest.mm +4 -0
  153. data/platform/iphone/CocoaHTTPServer/Core/Categories/DDData.h +14 -0
  154. data/platform/iphone/CocoaHTTPServer/Core/Categories/DDData.m +158 -0
  155. data/platform/iphone/CocoaHTTPServer/Core/Categories/DDNumber.h +12 -0
  156. data/platform/iphone/CocoaHTTPServer/Core/Categories/DDNumber.m +88 -0
  157. data/platform/iphone/CocoaHTTPServer/Core/Categories/DDRange.h +56 -0
  158. data/platform/iphone/CocoaHTTPServer/Core/Categories/DDRange.m +104 -0
  159. data/platform/iphone/CocoaHTTPServer/Core/HTTPAuthenticationRequest.h +45 -0
  160. data/platform/iphone/CocoaHTTPServer/Core/HTTPAuthenticationRequest.m +195 -0
  161. data/platform/iphone/CocoaHTTPServer/Core/HTTPConnection.h +120 -0
  162. data/platform/iphone/CocoaHTTPServer/Core/HTTPConnection.m +2708 -0
  163. data/platform/iphone/CocoaHTTPServer/Core/HTTPLogging.h +136 -0
  164. data/platform/iphone/CocoaHTTPServer/Core/HTTPMessage.h +48 -0
  165. data/platform/iphone/CocoaHTTPServer/Core/HTTPMessage.m +113 -0
  166. data/platform/iphone/CocoaHTTPServer/Core/HTTPResponse.h +149 -0
  167. data/platform/iphone/CocoaHTTPServer/Core/HTTPServer.h +205 -0
  168. data/platform/iphone/CocoaHTTPServer/Core/HTTPServer.m +772 -0
  169. data/platform/iphone/CocoaHTTPServer/Core/Mime/MultipartFormDataParser.h +65 -0
  170. data/platform/iphone/CocoaHTTPServer/Core/Mime/MultipartFormDataParser.m +529 -0
  171. data/platform/iphone/CocoaHTTPServer/Core/Mime/MultipartMessageHeader.h +33 -0
  172. data/platform/iphone/CocoaHTTPServer/Core/Mime/MultipartMessageHeader.m +86 -0
  173. data/platform/iphone/CocoaHTTPServer/Core/Mime/MultipartMessageHeaderField.h +23 -0
  174. data/platform/iphone/CocoaHTTPServer/Core/Mime/MultipartMessageHeaderField.m +211 -0
  175. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPAsyncFileResponse.h +75 -0
  176. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPAsyncFileResponse.m +405 -0
  177. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPDataResponse.h +13 -0
  178. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPDataResponse.m +79 -0
  179. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPDynamicFileResponse.h +52 -0
  180. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPDynamicFileResponse.m +292 -0
  181. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPErrorResponse.h +9 -0
  182. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPErrorResponse.m +38 -0
  183. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPFileResponse.h +25 -0
  184. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPFileResponse.m +237 -0
  185. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPRedirectResponse.h +12 -0
  186. data/platform/iphone/CocoaHTTPServer/Core/Responses/HTTPRedirectResponse.m +73 -0
  187. data/platform/iphone/CocoaHTTPServer/Core/WebSocket.h +105 -0
  188. data/platform/iphone/CocoaHTTPServer/Core/WebSocket.m +791 -0
  189. data/platform/iphone/CocoaHTTPServer/Extensions/WebDAV/DAVConnection.h +7 -0
  190. data/platform/iphone/CocoaHTTPServer/Extensions/WebDAV/DAVConnection.m +160 -0
  191. data/platform/iphone/CocoaHTTPServer/Extensions/WebDAV/DAVResponse.h +11 -0
  192. data/platform/iphone/CocoaHTTPServer/Extensions/WebDAV/DAVResponse.m +372 -0
  193. data/platform/iphone/CocoaHTTPServer/Extensions/WebDAV/DELETEResponse.h +7 -0
  194. data/platform/iphone/CocoaHTTPServer/Extensions/WebDAV/DELETEResponse.m +49 -0
  195. data/platform/iphone/CocoaHTTPServer/Extensions/WebDAV/PUTResponse.h +8 -0
  196. data/platform/iphone/CocoaHTTPServer/Extensions/WebDAV/PUTResponse.m +69 -0
  197. data/platform/iphone/CocoaHTTPServer/LICENSE.txt +18 -0
  198. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaAsyncSocket/About.txt +4 -0
  199. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaAsyncSocket/GCDAsyncSocket.h +1226 -0
  200. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaAsyncSocket/GCDAsyncSocket.m +8528 -0
  201. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/About.txt +33 -0
  202. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/DDASLLogger.h +41 -0
  203. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/DDASLLogger.m +99 -0
  204. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/DDAbstractDatabaseLogger.h +102 -0
  205. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/DDAbstractDatabaseLogger.m +727 -0
  206. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/DDFileLogger.h +334 -0
  207. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/DDFileLogger.m +1353 -0
  208. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/DDLog.h +601 -0
  209. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/DDLog.m +1083 -0
  210. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/DDTTYLogger.h +167 -0
  211. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/DDTTYLogger.m +1479 -0
  212. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/Extensions/ContextFilterLogFormatter.h +65 -0
  213. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/Extensions/ContextFilterLogFormatter.m +191 -0
  214. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/Extensions/DispatchQueueLogFormatter.h +116 -0
  215. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/Extensions/DispatchQueueLogFormatter.m +251 -0
  216. data/platform/iphone/CocoaHTTPServer/Vendor/CocoaLumberjack/Extensions/README.txt +7 -0
  217. data/platform/iphone/Framework/RhoApplication/RhoApplication.xcodeproj/project.pbxproj +1 -1
  218. data/platform/iphone/Framework/Rhodes/Rhodes.xcodeproj/project.pbxproj +2 -2
  219. data/platform/iphone/RhoAppBaseLib/RhoAppBaseLib.xcodeproj/project.pbxproj +410 -1
  220. data/platform/iphone/RhoLib/RhoLib.xcodeproj/project.pbxproj +1 -1
  221. data/platform/iphone/curl/curl.xcodeproj/project.pbxproj +4 -1
  222. data/platform/iphone/rbuild/iphone.rake +13 -8
  223. data/platform/iphone/rhoextlib/rhoextlib.xcodeproj/project.pbxproj +4 -1
  224. data/platform/iphone/rhorubylib/rhorubylib.xcodeproj/project.pbxproj +1 -1
  225. data/platform/iphone/rhosynclib/rhosynclib.xcodeproj/project.pbxproj +1 -1
  226. data/platform/osx/bin/RhoSimulator/RhoSimulator.app.zip +0 -0
  227. data/platform/sailfish/build/{harbour-SailfishRhodes.pro.erb → SailfishRhodes.pro.erb} +10 -17
  228. data/platform/sailfish/build/rhodes.pro.erb +7 -17
  229. data/platform/sailfish/build/rpm/SailfishRhodes.desktop.erb +12 -0
  230. data/platform/sailfish/build/rpm/SailfishRhodes.erb +2 -0
  231. data/platform/sailfish/build/rpm/SailfishRhodes.spec.erb +43 -0
  232. data/platform/sailfish/build/rubylib.pro.erb +29 -29
  233. data/platform/sailfish/build/sailfish.rake +188 -180
  234. data/platform/sailfish/keys/regular_cert.pem +14 -0
  235. data/platform/sailfish/keys/regular_key.pem +4 -0
  236. data/platform/shared/common/RhodesApp.cpp +59 -10
  237. data/platform/shared/common/iphone/RhoCryptImpl.mm +130 -54
  238. data/platform/shared/net/HttpServer.cpp +20 -0
  239. data/platform/shared/qt/RhoSimulator.pro +1 -1
  240. data/platform/shared/qt/rhodes/rhodes.pro +4 -11
  241. data/platform/shared/qt/sailfish/SailfishRhodes.desktop +3 -4
  242. data/platform/shared/qt/sailfish/SailfishRhodes.pro +9 -10
  243. data/platform/shared/qt/sailfish/icons/108x108/108x108.png +0 -0
  244. data/platform/shared/qt/sailfish/privileges/sailfishrhodes +2 -0
  245. data/platform/shared/qt/sailfish/qml/pages/FirstPageWK.qml +7 -11
  246. data/platform/shared/qt/sailfish/qml/{harbour-sailfishrhodes.qml → sailfishrhodes.qml} +1 -1
  247. data/platform/shared/qt/sailfish/rpm/sailfishrhodes.spec +80 -0
  248. data/platform/shared/qt/sailfish/rpm/{harbour-sailfishrhodes.yaml → sailfishrhodes.yaml} +2 -2
  249. data/platform/shared/qt/sailfish/src/QtMainWindow.cpp +1 -1
  250. data/platform/shared/qt/sailfish/src/QtMainWindow.h +1 -1
  251. data/platform/shared/qt/sailfish/src/main.cpp +6 -38
  252. data/platform/shared/qt/sailfish/src/rootdelegate.h +2 -14
  253. data/platform/shared/ruby/aurora/ruby/config.h +386 -0
  254. data/platform/shared/ruby/aurora/ruby/constdefs.c +5866 -0
  255. data/platform/shared/ruby/aurora/ruby/constdefs.h +1788 -0
  256. data/platform/shared/ruby/osx/ruby/config.h +2 -0
  257. data/platform/shared/ruby/win32/win32.c +10 -3
  258. data/platform/shared/sqlite/crypto.c +14 -0
  259. data/platform/win32/RhoSimulator/RhoSimulator.exe +0 -0
  260. data/platform/win32/build/rhodes.nsi +3 -3
  261. data/platform/win32/build/win32.rake +1 -1
  262. data/rakefile.rb +55 -43
  263. data/res/build-tools/RhoRuby.exe +0 -0
  264. data/res/build-tools/aapt2/linux/aapt2 +0 -0
  265. data/res/build-tools/aapt2/osx/aapt2 +0 -0
  266. data/res/build-tools/iphonesim/build/Release/iphonesim_8 +4 -4
  267. data/res/generators/templates/application/AndroidManifest.erb +28 -6
  268. data/res/generators/templates/application/build.yml +18 -11
  269. data/res/generators/templates/application/resources/android/res/xml/provider_paths.xml +4 -0
  270. data/res/generators/templates/application/rhoconfig.txt +15 -1
  271. data/res/generators/templates/iphone_project/Bremen8.xcodeproj/project.pbxproj +24 -1
  272. data/res/generators/templates/iphone_project/Classes/SimpleSwiftClass.swift +20 -0
  273. data/res/generators/templates/iphone_project/Classes/rhorunner-Bridging-Header.h +4 -0
  274. data/rhobuild.yml.example +4 -4
  275. data/rhodes.gemspec +4 -3
  276. data/version +1 -1
  277. metadata +157 -57
  278. data/lib/commonAPI/mediacapture/ext/platform/android/adds/res/drawable/camera_btn.xml +0 -14
  279. data/lib/commonAPI/mediacapture/ext/platform/android/adds/res/layout/camera_land.xml +0 -23
  280. data/lib/commonAPI/mediacapture/ext/platform/android/adds/res/layout/camera_port.xml +0 -23
  281. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/CameraActivity.java +0 -156
  282. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/CameraEclair.java +0 -227
  283. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/CameraGingerbread.java +0 -152
  284. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/CameraPreview.java +0 -183
  285. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/CameraSingletonEclair.java +0 -14
  286. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/CameraSingletonGingerbread.java +0 -60
  287. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/ICameraObject.java +0 -20
  288. data/lib/commonAPI/mediacapture/ext/platform/android/src/com/rho/camera/ICameraSingletonObject.java +0 -8
  289. data/lib/extensions/fcm-push/ext/android/src/com/rhomobile/rhodes/fcm/FCMTokenRefresherService.java +0 -27
  290. data/platform/android/Rhodes/AndroidManifest.xml.erb +0 -89
  291. data/platform/sailfish/build/rho_build.cmd.erb +0 -14
  292. data/platform/sailfish/build/rho_clean.cmd.erb +0 -14
  293. data/platform/sailfish/build/rho_deploy.cmd.erb +0 -15
  294. data/platform/sailfish/build/rho_rpm.cmd.erb +0 -14
  295. data/platform/sailfish/build/rho_rpmvalidation.cmd.erb +0 -14
  296. data/platform/sailfish/build/rpm/harbour-SailfishRhodes.desktop.erb +0 -7
  297. data/platform/sailfish/build/rpm/harbour-SailfishRhodes.erb +0 -2
  298. data/platform/sailfish/build/rpm/harbour-SailfishRhodes.yaml.erb +0 -37
  299. data/platform/shared/qt/sailfish/harbour-sailfishrhodes.desktop +0 -6
  300. data/platform/shared/qt/sailfish/icons/108x108/harbour-sailfishrhodes.png +0 -0
  301. data/platform/shared/qt/sailfish/privileges/harbour-sailfishrhodes +0 -2
  302. data/platform/shared/qt/sailfish/qml/pages/FirstPageWE.qml +0 -236
  303. /data/platform/shared/qt/sailfish/icons/128x128/{harbour-sailfishrhodes.png → sailfishrhodes.png} +0 -0
  304. /data/platform/shared/qt/sailfish/icons/172x172/{harbour-sailfishrhodes.png → sailfishrhodes.png} +0 -0
  305. /data/platform/shared/qt/sailfish/icons/86x86/{harbour-sailfishrhodes.png → sailfishrhodes.png} +0 -0
@@ -0,0 +1,772 @@
1
+ #import "HTTPServer.h"
2
+ #import "GCDAsyncSocket.h"
3
+ #import "HTTPConnection.h"
4
+ #import "WebSocket.h"
5
+ #import "HTTPLogging.h"
6
+
7
+ #if ! __has_feature(objc_arc)
8
+ #warning This file must be compiled with ARC. Use -fobjc-arc flag (or convert project to ARC).
9
+ #endif
10
+
11
+ // Log levels: off, error, warn, info, verbose
12
+ // Other flags: trace
13
+ static const int httpLogLevel = HTTP_LOG_LEVEL_INFO; // | HTTP_LOG_FLAG_TRACE;
14
+
15
+ @interface HTTPServer (PrivateAPI)
16
+
17
+ - (void)unpublishBonjour;
18
+ - (void)publishBonjour;
19
+
20
+ + (void)startBonjourThreadIfNeeded;
21
+ + (void)performBonjourBlock:(dispatch_block_t)block;
22
+
23
+ @end
24
+
25
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
26
+ #pragma mark -
27
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
28
+
29
+ @implementation HTTPServer
30
+
31
+ /**
32
+ * Standard Constructor.
33
+ * Instantiates an HTTP server, but does not start it.
34
+ **/
35
+ - (id)init
36
+ {
37
+ if ((self = [super init]))
38
+ {
39
+ HTTPLogTrace();
40
+
41
+ // Setup underlying dispatch queues
42
+ serverQueue = dispatch_queue_create("HTTPServer", NULL);
43
+ connectionQueue = dispatch_queue_create("HTTPConnection", NULL);
44
+
45
+ IsOnServerQueueKey = &IsOnServerQueueKey;
46
+ IsOnConnectionQueueKey = &IsOnConnectionQueueKey;
47
+
48
+ void *nonNullUnusedPointer = (__bridge void *)self; // Whatever, just not null
49
+
50
+ dispatch_queue_set_specific(serverQueue, IsOnServerQueueKey, nonNullUnusedPointer, NULL);
51
+ dispatch_queue_set_specific(connectionQueue, IsOnConnectionQueueKey, nonNullUnusedPointer, NULL);
52
+
53
+ // Initialize underlying GCD based tcp socket
54
+ asyncSocket = [[GCDAsyncSocket alloc] initWithDelegate:self delegateQueue:serverQueue];
55
+
56
+ // Use default connection class of HTTPConnection
57
+ connectionClass = [HTTPConnection self];
58
+
59
+ // By default bind on all available interfaces, en1, wifi etc
60
+ interface = nil;
61
+
62
+ // Use a default port of 0
63
+ // This will allow the kernel to automatically pick an open port for us
64
+ port = 0;
65
+
66
+ // Configure default values for bonjour service
67
+
68
+ // Bonjour domain. Use the local domain by default
69
+ domain = @"local.";
70
+
71
+ // If using an empty string ("") for the service name when registering,
72
+ // the system will automatically use the "Computer Name".
73
+ // Passing in an empty string will also handle name conflicts
74
+ // by automatically appending a digit to the end of the name.
75
+ name = @"";
76
+
77
+ // Initialize arrays to hold all the HTTP and webSocket connections
78
+ connections = [[NSMutableArray alloc] init];
79
+ webSockets = [[NSMutableArray alloc] init];
80
+
81
+ connectionsLock = [[NSLock alloc] init];
82
+ webSocketsLock = [[NSLock alloc] init];
83
+
84
+ // Register for notifications of closed connections
85
+ [[NSNotificationCenter defaultCenter] addObserver:self
86
+ selector:@selector(connectionDidDie:)
87
+ name:HTTPConnectionDidDieNotification
88
+ object:nil];
89
+
90
+ // Register for notifications of closed websocket connections
91
+ [[NSNotificationCenter defaultCenter] addObserver:self
92
+ selector:@selector(webSocketDidDie:)
93
+ name:WebSocketDidDieNotification
94
+ object:nil];
95
+
96
+ isRunning = NO;
97
+ }
98
+ return self;
99
+ }
100
+
101
+ /**
102
+ * Standard Deconstructor.
103
+ * Stops the server, and clients, and releases any resources connected with this instance.
104
+ **/
105
+ - (void)dealloc
106
+ {
107
+ HTTPLogTrace();
108
+
109
+ // Remove notification observer
110
+ [[NSNotificationCenter defaultCenter] removeObserver:self];
111
+
112
+ // Stop the server if it's running
113
+ [self stop];
114
+
115
+ // Release all instance variables
116
+
117
+ #if !OS_OBJECT_USE_OBJC
118
+ dispatch_release(serverQueue);
119
+ dispatch_release(connectionQueue);
120
+ #endif
121
+
122
+ [asyncSocket setDelegate:nil delegateQueue:NULL];
123
+ }
124
+
125
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
126
+ #pragma mark Server Configuration
127
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
128
+
129
+ /**
130
+ * The document root is filesystem root for the webserver.
131
+ * Thus requests for /index.html will be referencing the index.html file within the document root directory.
132
+ * All file requests are relative to this document root.
133
+ **/
134
+ - (NSString *)documentRoot
135
+ {
136
+ __block NSString *result;
137
+
138
+ dispatch_sync(serverQueue, ^{
139
+ result = documentRoot;
140
+ });
141
+
142
+ return result;
143
+ }
144
+
145
+ - (void)setDocumentRoot:(NSString *)value
146
+ {
147
+ HTTPLogTrace();
148
+
149
+ // Document root used to be of type NSURL.
150
+ // Add type checking for early warning to developers upgrading from older versions.
151
+
152
+ if (value && ![value isKindOfClass:[NSString class]])
153
+ {
154
+ HTTPLogWarn(@"%@: %@ - Expecting NSString parameter, received %@ parameter",
155
+ THIS_FILE, THIS_METHOD, NSStringFromClass([value class]));
156
+ return;
157
+ }
158
+
159
+ NSString *valueCopy = [value copy];
160
+
161
+ dispatch_async(serverQueue, ^{
162
+ documentRoot = valueCopy;
163
+ });
164
+
165
+ }
166
+
167
+ /**
168
+ * The connection class is the class that will be used to handle connections.
169
+ * That is, when a new connection is created, an instance of this class will be intialized.
170
+ * The default connection class is HTTPConnection.
171
+ * If you use a different connection class, it is assumed that the class extends HTTPConnection
172
+ **/
173
+ - (Class)connectionClass
174
+ {
175
+ __block Class result;
176
+
177
+ dispatch_sync(serverQueue, ^{
178
+ result = connectionClass;
179
+ });
180
+
181
+ return result;
182
+ }
183
+
184
+ - (void)setConnectionClass:(Class)value
185
+ {
186
+ HTTPLogTrace();
187
+
188
+ dispatch_async(serverQueue, ^{
189
+ connectionClass = value;
190
+ });
191
+ }
192
+
193
+ /**
194
+ * What interface to bind the listening socket to.
195
+ **/
196
+ - (NSString *)interface
197
+ {
198
+ __block NSString *result;
199
+
200
+ dispatch_sync(serverQueue, ^{
201
+ result = interface;
202
+ });
203
+
204
+ return result;
205
+ }
206
+
207
+ - (void)setInterface:(NSString *)value
208
+ {
209
+ NSString *valueCopy = [value copy];
210
+
211
+ dispatch_async(serverQueue, ^{
212
+ interface = valueCopy;
213
+ });
214
+
215
+ }
216
+
217
+ /**
218
+ * The port to listen for connections on.
219
+ * By default this port is initially set to zero, which allows the kernel to pick an available port for us.
220
+ * After the HTTP server has started, the port being used may be obtained by this method.
221
+ **/
222
+ - (UInt16)port
223
+ {
224
+ __block UInt16 result;
225
+
226
+ dispatch_sync(serverQueue, ^{
227
+ result = port;
228
+ });
229
+
230
+ return result;
231
+ }
232
+
233
+ - (UInt16)listeningPort
234
+ {
235
+ __block UInt16 result;
236
+
237
+ dispatch_sync(serverQueue, ^{
238
+ if (isRunning)
239
+ result = [asyncSocket localPort];
240
+ else
241
+ result = 0;
242
+ });
243
+
244
+ return result;
245
+ }
246
+
247
+ - (void)setPort:(UInt16)value
248
+ {
249
+ HTTPLogTrace();
250
+
251
+ dispatch_async(serverQueue, ^{
252
+ port = value;
253
+ });
254
+ }
255
+
256
+ /**
257
+ * Domain on which to broadcast this service via Bonjour.
258
+ * The default domain is @"local".
259
+ **/
260
+ - (NSString *)domain
261
+ {
262
+ __block NSString *result;
263
+
264
+ dispatch_sync(serverQueue, ^{
265
+ result = domain;
266
+ });
267
+
268
+ return result;
269
+ }
270
+
271
+ - (void)setDomain:(NSString *)value
272
+ {
273
+ HTTPLogTrace();
274
+
275
+ NSString *valueCopy = [value copy];
276
+
277
+ dispatch_async(serverQueue, ^{
278
+ domain = valueCopy;
279
+ });
280
+
281
+ }
282
+
283
+ /**
284
+ * The name to use for this service via Bonjour.
285
+ * The default name is an empty string,
286
+ * which should result in the published name being the host name of the computer.
287
+ **/
288
+ - (NSString *)name
289
+ {
290
+ __block NSString *result;
291
+
292
+ dispatch_sync(serverQueue, ^{
293
+ result = name;
294
+ });
295
+
296
+ return result;
297
+ }
298
+
299
+ - (NSString *)publishedName
300
+ {
301
+ __block NSString *result;
302
+
303
+ dispatch_sync(serverQueue, ^{
304
+
305
+ if (netService == nil)
306
+ {
307
+ result = nil;
308
+ }
309
+ else
310
+ {
311
+
312
+ dispatch_block_t bonjourBlock = ^{
313
+ result = [[netService name] copy];
314
+ };
315
+
316
+ [[self class] performBonjourBlock:bonjourBlock];
317
+ }
318
+ });
319
+
320
+ return result;
321
+ }
322
+
323
+ - (void)setName:(NSString *)value
324
+ {
325
+ NSString *valueCopy = [value copy];
326
+
327
+ dispatch_async(serverQueue, ^{
328
+ name = valueCopy;
329
+ });
330
+
331
+ }
332
+
333
+ /**
334
+ * The type of service to publish via Bonjour.
335
+ * No type is set by default, and one must be set in order for the service to be published.
336
+ **/
337
+ - (NSString *)type
338
+ {
339
+ __block NSString *result;
340
+
341
+ dispatch_sync(serverQueue, ^{
342
+ result = type;
343
+ });
344
+
345
+ return result;
346
+ }
347
+
348
+ - (void)setType:(NSString *)value
349
+ {
350
+ NSString *valueCopy = [value copy];
351
+
352
+ dispatch_async(serverQueue, ^{
353
+ type = valueCopy;
354
+ });
355
+
356
+ }
357
+
358
+ /**
359
+ * The extra data to use for this service via Bonjour.
360
+ **/
361
+ - (NSDictionary *)TXTRecordDictionary
362
+ {
363
+ __block NSDictionary *result;
364
+
365
+ dispatch_sync(serverQueue, ^{
366
+ result = txtRecordDictionary;
367
+ });
368
+
369
+ return result;
370
+ }
371
+
372
+ - (void)setTXTRecordDictionary:(NSDictionary *)value
373
+ {
374
+ HTTPLogTrace();
375
+
376
+ NSDictionary *valueCopy = [value copy];
377
+
378
+ dispatch_async(serverQueue, ^{
379
+
380
+ txtRecordDictionary = valueCopy;
381
+
382
+ // Update the txtRecord of the netService if it has already been published
383
+ if (netService)
384
+ {
385
+ NSNetService *theNetService = netService;
386
+ NSData *txtRecordData = nil;
387
+ if (txtRecordDictionary)
388
+ txtRecordData = [NSNetService dataFromTXTRecordDictionary:txtRecordDictionary];
389
+
390
+ dispatch_block_t bonjourBlock = ^{
391
+ [theNetService setTXTRecordData:txtRecordData];
392
+ };
393
+
394
+ [[self class] performBonjourBlock:bonjourBlock];
395
+ }
396
+ });
397
+
398
+ }
399
+
400
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
401
+ #pragma mark Server Control
402
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
403
+
404
+ - (BOOL)start:(NSError **)errPtr
405
+ {
406
+ HTTPLogTrace();
407
+
408
+ __block BOOL success = YES;
409
+ __block NSError *err = nil;
410
+
411
+ dispatch_sync(serverQueue, ^{ @autoreleasepool {
412
+
413
+ success = [asyncSocket acceptOnInterface:interface port:port error:&err];
414
+ if (success)
415
+ {
416
+ HTTPLogInfo(@"%@: Started HTTP server on port %hu", THIS_FILE, [asyncSocket localPort]);
417
+
418
+ isRunning = YES;
419
+ [self publishBonjour];
420
+ }
421
+ else
422
+ {
423
+ HTTPLogError(@"%@: Failed to start HTTP Server: %@", THIS_FILE, err);
424
+ }
425
+ }});
426
+
427
+ if (errPtr)
428
+ *errPtr = err;
429
+
430
+ return success;
431
+ }
432
+
433
+ - (void)stop
434
+ {
435
+ [self stop:NO];
436
+ }
437
+
438
+ - (void)stop:(BOOL)keepExistingConnections
439
+ {
440
+ HTTPLogTrace();
441
+
442
+ dispatch_sync(serverQueue, ^{ @autoreleasepool {
443
+
444
+ // First stop publishing the service via bonjour
445
+ [self unpublishBonjour];
446
+
447
+ // Stop listening / accepting incoming connections
448
+ [asyncSocket disconnect];
449
+ isRunning = NO;
450
+
451
+ if (!keepExistingConnections)
452
+ {
453
+ // Stop all HTTP connections the server owns
454
+ [connectionsLock lock];
455
+ for (HTTPConnection *connection in connections)
456
+ {
457
+ [connection stop];
458
+ }
459
+ [connections removeAllObjects];
460
+ [connectionsLock unlock];
461
+
462
+ // Stop all WebSocket connections the server owns
463
+ [webSocketsLock lock];
464
+ for (WebSocket *webSocket in webSockets)
465
+ {
466
+ [webSocket stop];
467
+ }
468
+ [webSockets removeAllObjects];
469
+ [webSocketsLock unlock];
470
+ }
471
+ }});
472
+ }
473
+
474
+ - (BOOL)isRunning
475
+ {
476
+ __block BOOL result;
477
+
478
+ dispatch_sync(serverQueue, ^{
479
+ result = isRunning;
480
+ });
481
+
482
+ return result;
483
+ }
484
+
485
+ - (void)addWebSocket:(WebSocket *)ws
486
+ {
487
+ [webSocketsLock lock];
488
+
489
+ HTTPLogTrace();
490
+ [webSockets addObject:ws];
491
+
492
+ [webSocketsLock unlock];
493
+ }
494
+
495
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
496
+ #pragma mark Server Status
497
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
498
+
499
+ /**
500
+ * Returns the number of http client connections that are currently connected to the server.
501
+ **/
502
+ - (NSUInteger)numberOfHTTPConnections
503
+ {
504
+ NSUInteger result = 0;
505
+
506
+ [connectionsLock lock];
507
+ result = [connections count];
508
+ [connectionsLock unlock];
509
+
510
+ return result;
511
+ }
512
+
513
+ /**
514
+ * Returns the number of websocket client connections that are currently connected to the server.
515
+ **/
516
+ - (NSUInteger)numberOfWebSocketConnections
517
+ {
518
+ NSUInteger result = 0;
519
+
520
+ [webSocketsLock lock];
521
+ result = [webSockets count];
522
+ [webSocketsLock unlock];
523
+
524
+ return result;
525
+ }
526
+
527
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
528
+ #pragma mark Incoming Connections
529
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
530
+
531
+ - (HTTPConfig *)config
532
+ {
533
+ // Override me if you want to provide a custom config to the new connection.
534
+ //
535
+ // Generally this involves overriding the HTTPConfig class to include any custom settings,
536
+ // and then having this method return an instance of 'MyHTTPConfig'.
537
+
538
+ // Note: Think you can make the server faster by putting each connection on its own queue?
539
+ // Then benchmark it before and after and discover for yourself the shocking truth!
540
+ //
541
+ // Try the apache benchmark tool (already installed on your Mac):
542
+ // $ ab -n 1000 -c 1 http://localhost:<port>/some_path.html
543
+
544
+ return [[HTTPConfig alloc] initWithServer:self documentRoot:documentRoot queue:connectionQueue];
545
+ }
546
+
547
+ - (void)socket:(GCDAsyncSocket *)sock didAcceptNewSocket:(GCDAsyncSocket *)newSocket
548
+ {
549
+ HTTPConnection *newConnection = (HTTPConnection *)[[connectionClass alloc] initWithAsyncSocket:newSocket
550
+ configuration:[self config]];
551
+ [connectionsLock lock];
552
+ [connections addObject:newConnection];
553
+ [connectionsLock unlock];
554
+
555
+ [newConnection start];
556
+ }
557
+
558
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
559
+ #pragma mark Bonjour
560
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
561
+
562
+ - (void)publishBonjour
563
+ {
564
+ HTTPLogTrace();
565
+
566
+ NSAssert(dispatch_get_specific(IsOnServerQueueKey) != NULL, @"Must be on serverQueue");
567
+
568
+ if (type)
569
+ {
570
+ netService = [[NSNetService alloc] initWithDomain:domain type:type name:name port:[asyncSocket localPort]];
571
+ [netService setDelegate:self];
572
+
573
+ NSNetService *theNetService = netService;
574
+ NSData *txtRecordData = nil;
575
+ if (txtRecordDictionary)
576
+ txtRecordData = [NSNetService dataFromTXTRecordDictionary:txtRecordDictionary];
577
+
578
+ dispatch_block_t bonjourBlock = ^{
579
+
580
+ [theNetService removeFromRunLoop:[NSRunLoop mainRunLoop] forMode:NSRunLoopCommonModes];
581
+ [theNetService scheduleInRunLoop:[NSRunLoop currentRunLoop] forMode:NSRunLoopCommonModes];
582
+ [theNetService publish];
583
+
584
+ // Do not set the txtRecordDictionary prior to publishing!!!
585
+ // This will cause the OS to crash!!!
586
+ if (txtRecordData)
587
+ {
588
+ [theNetService setTXTRecordData:txtRecordData];
589
+ }
590
+ };
591
+
592
+ [[self class] startBonjourThreadIfNeeded];
593
+ [[self class] performBonjourBlock:bonjourBlock];
594
+ }
595
+ }
596
+
597
+ - (void)unpublishBonjour
598
+ {
599
+ HTTPLogTrace();
600
+
601
+ NSAssert(dispatch_get_specific(IsOnServerQueueKey) != NULL, @"Must be on serverQueue");
602
+
603
+ if (netService)
604
+ {
605
+ NSNetService *theNetService = netService;
606
+
607
+ dispatch_block_t bonjourBlock = ^{
608
+
609
+ [theNetService stop];
610
+ };
611
+
612
+ [[self class] performBonjourBlock:bonjourBlock];
613
+
614
+ netService = nil;
615
+ }
616
+ }
617
+
618
+ /**
619
+ * Republishes the service via bonjour if the server is running.
620
+ * If the service was not previously published, this method will publish it (if the server is running).
621
+ **/
622
+ - (void)republishBonjour
623
+ {
624
+ HTTPLogTrace();
625
+
626
+ dispatch_async(serverQueue, ^{
627
+
628
+ [self unpublishBonjour];
629
+ [self publishBonjour];
630
+ });
631
+ }
632
+
633
+ /**
634
+ * Called when our bonjour service has been successfully published.
635
+ * This method does nothing but output a log message telling us about the published service.
636
+ **/
637
+ - (void)netServiceDidPublish:(NSNetService *)ns
638
+ {
639
+ // Override me to do something here...
640
+ //
641
+ // Note: This method is invoked on our bonjour thread.
642
+
643
+ HTTPLogInfo(@"Bonjour Service Published: domain(%@) type(%@) name(%@)", [ns domain], [ns type], [ns name]);
644
+ }
645
+
646
+ /**
647
+ * Called if our bonjour service failed to publish itself.
648
+ * This method does nothing but output a log message telling us about the published service.
649
+ **/
650
+ - (void)netService:(NSNetService *)ns didNotPublish:(NSDictionary *)errorDict
651
+ {
652
+ // Override me to do something here...
653
+ //
654
+ // Note: This method in invoked on our bonjour thread.
655
+
656
+ HTTPLogWarn(@"Failed to Publish Service: domain(%@) type(%@) name(%@) - %@",
657
+ [ns domain], [ns type], [ns name], errorDict);
658
+ }
659
+
660
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
661
+ #pragma mark Notifications
662
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
663
+
664
+ /**
665
+ * This method is automatically called when a notification of type HTTPConnectionDidDieNotification is posted.
666
+ * It allows us to remove the connection from our array.
667
+ **/
668
+ - (void)connectionDidDie:(NSNotification *)notification
669
+ {
670
+ // Note: This method is called on the connection queue that posted the notification
671
+
672
+ [connectionsLock lock];
673
+
674
+ HTTPLogTrace();
675
+ [connections removeObject:[notification object]];
676
+
677
+ [connectionsLock unlock];
678
+ }
679
+
680
+ /**
681
+ * This method is automatically called when a notification of type WebSocketDidDieNotification is posted.
682
+ * It allows us to remove the websocket from our array.
683
+ **/
684
+ - (void)webSocketDidDie:(NSNotification *)notification
685
+ {
686
+ // Note: This method is called on the connection queue that posted the notification
687
+
688
+ [webSocketsLock lock];
689
+
690
+ HTTPLogTrace();
691
+ [webSockets removeObject:[notification object]];
692
+
693
+ [webSocketsLock unlock];
694
+ }
695
+
696
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
697
+ #pragma mark Bonjour Thread
698
+ ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
699
+
700
+ /**
701
+ * NSNetService is runloop based, so it requires a thread with a runloop.
702
+ * This gives us two options:
703
+ *
704
+ * - Use the main thread
705
+ * - Setup our own dedicated thread
706
+ *
707
+ * Since we have various blocks of code that need to synchronously access the netservice objects,
708
+ * using the main thread becomes troublesome and a potential for deadlock.
709
+ **/
710
+
711
+ static NSThread *bonjourThread;
712
+
713
+ + (void)startBonjourThreadIfNeeded
714
+ {
715
+ HTTPLogTrace();
716
+
717
+ static dispatch_once_t predicate;
718
+ dispatch_once(&predicate, ^{
719
+
720
+ HTTPLogVerbose(@"%@: Starting bonjour thread...", THIS_FILE);
721
+
722
+ bonjourThread = [[NSThread alloc] initWithTarget:self
723
+ selector:@selector(bonjourThread)
724
+ object:nil];
725
+ [bonjourThread start];
726
+ });
727
+ }
728
+
729
+ + (void)bonjourThread
730
+ {
731
+ @autoreleasepool {
732
+
733
+ HTTPLogVerbose(@"%@: BonjourThread: Started", THIS_FILE);
734
+
735
+ // We can't run the run loop unless it has an associated input source or a timer.
736
+ // So we'll just create a timer that will never fire - unless the server runs for 10,000 years.
737
+ #pragma clang diagnostic push
738
+ #pragma clang diagnostic ignored "-Wundeclared-selector"
739
+ [NSTimer scheduledTimerWithTimeInterval:[[NSDate distantFuture] timeIntervalSinceNow]
740
+ target:self
741
+ selector:@selector(donothingatall:)
742
+ userInfo:nil
743
+ repeats:YES];
744
+ #pragma clang diagnostic pop
745
+
746
+ [[NSRunLoop currentRunLoop] run];
747
+
748
+ HTTPLogVerbose(@"%@: BonjourThread: Aborted", THIS_FILE);
749
+
750
+ }
751
+ }
752
+
753
+ + (void)executeBonjourBlock:(dispatch_block_t)block
754
+ {
755
+ HTTPLogTrace();
756
+
757
+ NSAssert([NSThread currentThread] == bonjourThread, @"Executed on incorrect thread");
758
+
759
+ block();
760
+ }
761
+
762
+ + (void)performBonjourBlock:(dispatch_block_t)block
763
+ {
764
+ HTTPLogTrace();
765
+
766
+ [self performSelector:@selector(executeBonjourBlock:)
767
+ onThread:bonjourThread
768
+ withObject:block
769
+ waitUntilDone:YES];
770
+ }
771
+
772
+ @end