jsgui3-server 0.0.121 → 0.0.122

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 (278) hide show
  1. package/.vscode/settings.json +6 -0
  2. package/README.md +10 -10
  3. package/controls/Active_HTML_Document.js +116 -116
  4. package/controls/README.md +7 -7
  5. package/controls/page/admin.js +74 -74
  6. package/controls/panel/admin.js +11 -11
  7. package/examples/_css/basic.css +913 -913
  8. package/examples/_css/database-control.css +51 -51
  9. package/examples/_css/jsgui.css +66 -66
  10. package/examples/_css/multi-layout.css +23 -23
  11. package/examples/_css/style.css +1669 -1669
  12. package/examples/_css/top-and-bottom-bars.css +54 -54
  13. package/examples/box/1) square box/client.js +188 -188
  14. package/examples/box/1) square box/server.js +112 -112
  15. package/examples/box/2) twenty square boxes/css flex wrap/client.js +248 -248
  16. package/examples/box/2) twenty square boxes/css flex wrap/server.js +112 -112
  17. package/examples/boxes/square_boxes.js +45 -48
  18. package/examples/boxes/square_boxes_client.js +132 -136
  19. package/examples/client-side-popup-menu-button.html +93 -93
  20. package/examples/color_palette.js +51 -51
  21. package/examples/color_palette_client.js +95 -95
  22. package/examples/controls/1) window/client.js +186 -186
  23. package/examples/controls/1) window/server.js +117 -117
  24. package/examples/controls/10) window, mirrored text inputs/client.js +320 -320
  25. package/examples/controls/10) window, mirrored text inputs/server.js +117 -117
  26. package/examples/controls/11) window, mirrored text fields/client.js +493 -251
  27. package/examples/controls/11) window, mirrored text fields/server.js +117 -117
  28. package/examples/controls/11b) window, shared Data_Object model mirrored text fields/client.js +613 -331
  29. package/examples/controls/11b) window, shared Data_Object model mirrored text fields/server.js +117 -117
  30. package/examples/controls/11c) window, shared Data_Value model mirrored text fields/client.js +617 -617
  31. package/examples/controls/11c) window, shared Data_Value model mirrored text fields/server.js +117 -117
  32. package/examples/controls/11d) window, shared model mirrored integer text fields/client.js +611 -280
  33. package/examples/controls/11d) window, shared model mirrored integer text fields/server.js +134 -22
  34. package/examples/controls/12) window, Select_Options control/client.js +435 -452
  35. package/examples/controls/12) window, Select_Options control/server.js +117 -117
  36. package/examples/controls/2) two windows/client.js +193 -193
  37. package/examples/controls/2) two windows/server.js +113 -113
  38. package/examples/controls/3) five windows/client.js +217 -217
  39. package/examples/controls/3) five windows/server.js +116 -115
  40. package/examples/controls/4) window, tabbed panel/client.js +54 -225
  41. package/examples/controls/4) window, tabbed panel/server.js +17 -117
  42. package/examples/controls/5) window, grid/client.js +204 -484
  43. package/examples/controls/5) window, grid/server.js +117 -119
  44. package/examples/controls/6) window, color_palette/client.js +204 -204
  45. package/examples/controls/6) window, color_palette/server.js +117 -117
  46. package/examples/controls/7) window, month_view/client.js +40 -231
  47. package/examples/controls/7) window, month_view/server.js +117 -117
  48. package/examples/controls/8) window, checkbox/client.js +247 -209
  49. package/examples/controls/8) window, checkbox/server.js +117 -117
  50. package/examples/controls/9) window, date picker/client.js +303 -303
  51. package/examples/controls/9) window, date picker/server.js +117 -117
  52. package/examples/controls/9b) window, shared data.model mirrored date pickers/client.js +398 -398
  53. package/examples/controls/9b) window, shared data.model mirrored date pickers/server.js +117 -117
  54. package/examples/controls/__old/_html-server-color-palette.js +114 -114
  55. package/examples/controls/__old/html-server-combo-box.js +104 -104
  56. package/examples/controls/__old/html-server-list.js +98 -98
  57. package/examples/controls/__old/html-server-popup-menu-button.js +114 -114
  58. package/examples/controls/__old/html-server-start-stop-toggle-button.js +146 -146
  59. package/examples/controls/__old/scs-arrow-button.js +36 -36
  60. package/examples/controls/__old/scs-date-picker.js +157 -157
  61. package/examples/controls/__old/scs-file-browser.js +82 -82
  62. package/examples/controls/__old/scs-item.js +159 -159
  63. package/examples/controls/__old/scs-month-arrow-selector.js +126 -126
  64. package/examples/controls/__old/scs-month-view.js +94 -94
  65. package/examples/controls/__old/scs-start-stop-toggle-button.js +40 -40
  66. package/examples/controls/__old/scs-tree.js +49 -49
  67. package/examples/controls/__old/scs-year-arrow-selector.js +127 -127
  68. package/examples/demos/date-picker.js +119 -119
  69. package/examples/demos/explain-encapsulation.js +9 -9
  70. package/examples/demos/resizing.js +35 -35
  71. package/examples/demos/server_time.js +6 -6
  72. package/examples/grids/grid_1.js +45 -45
  73. package/examples/grids/grid_1_client.js +329 -329
  74. package/examples/html-rendering.js +20 -20
  75. package/examples/html-server.js +105 -105
  76. package/examples/introducing jsgui3/server.js +110 -110
  77. package/examples/mx_display/mx_display_1.js +45 -45
  78. package/examples/mx_display/mx_display_1_client.js +444 -444
  79. package/fs2.js +1836 -1836
  80. package/http/responders/HTTP_Responder.js +15 -15
  81. package/http/responders/static/Static_Route_HTTP_Responder.js +105 -105
  82. package/module.js +34 -34
  83. package/old/_single-control-server.js +418 -418
  84. package/old/single-control-server.js +368 -368
  85. package/old/single-page-app.js +131 -131
  86. package/package.json +42 -42
  87. package/page-context.js +92 -92
  88. package/publishers/helpers/assigners/Assigner.js +10 -10
  89. package/publishers/helpers/assigners/static-compressed-response-buffers/Single_Control_Webpage_Server_Static_Compressed_Response_Buffers_Assigner.js +150 -150
  90. package/publishers/helpers/assigners/static-headers/Single_Control_Webpage_Server_Static_Headers_Assigner.js +109 -109
  91. package/publishers/helpers/assigners/static-routes/Single_Control_Webpage_Server_Static_Routes_Assigner.js +91 -91
  92. package/publishers/helpers/assigners/static-uncompressed-response-buffers/Single_Control_Webpage_Server_Static_Uncompressed_Response_Buffers_Assigner.js +104 -104
  93. package/publishers/helpers/preparers/static/bundle/Ready_To_Serve_Preparer.js +18 -18
  94. package/publishers/helpers/preparers/static/bundle/Static_Routes_Responses_Webpage_Bundle_Preparer.js +44 -44
  95. package/publishers/http-function-publisher.js +212 -212
  96. package/publishers/http-html-page-publisher.js +5 -5
  97. package/publishers/http-html-publisher.js +24 -24
  98. package/publishers/http-js-publisher.js +135 -135
  99. package/publishers/http-observable-publisher.js +124 -124
  100. package/publishers/http-publisher.js +53 -53
  101. package/publishers/http-resource-publisher.js +325 -325
  102. package/publishers/http-webpage-publisher.js +659 -658
  103. package/publishers/http-webpageorsite-publisher.js +343 -343
  104. package/publishers/http-website-publisher.js +640 -640
  105. package/publishers/notes.md +9 -9
  106. package/resources/README.md +16 -16
  107. package/resources/_old_website-javascript-resource.js +994 -994
  108. package/resources/_old_website-resource.js +507 -507
  109. package/resources/compile/server-resource-compilation.js +43 -43
  110. package/resources/data-resource.js +118 -118
  111. package/resources/fs-resource.js +146 -146
  112. package/resources/jsbuilder/Abstract_Single_Declaration.js +105 -105
  113. package/resources/jsbuilder/Abstract_Single_Declaration_Sequence.js +42 -42
  114. package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node.js +61 -61
  115. package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node_Group.js +41 -41
  116. package/resources/jsbuilder/JS_AST/JS_AST_Group_Shared.js +61 -61
  117. package/resources/jsbuilder/JS_AST/JS_AST_Node.js +93 -93
  118. package/resources/jsbuilder/JS_AST/JS_AST_Node_0-Core.js +253 -253
  119. package/resources/jsbuilder/JS_AST/JS_AST_Node_1-Babel.js +337 -337
  120. package/resources/jsbuilder/JS_AST/JS_AST_Node_10-Changing.js +39 -39
  121. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.1-Child.js +96 -96
  122. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.2-Parent.js +37 -37
  123. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.3-Ancestor.js +61 -61
  124. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.2-Inner.js +43 -43
  125. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.3-All.js +72 -72
  126. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.4-Sibling.js +92 -92
  127. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.5-Available_In_Scope.js +29 -29
  128. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.9-Signature.js +116 -116
  129. package/resources/jsbuilder/JS_AST/JS_AST_Node_3-Basics.js +159 -159
  130. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.0-Basics_First.js +178 -178
  131. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.1-Basics_Second.js +87 -87
  132. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.99-Basics_Last.js +91 -91
  133. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1-Basics_Each.js +136 -136
  134. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1.5-Basics_Count.js +73 -73
  135. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.2-Basics_Filter.js +39 -39
  136. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.3-Basics_Collect.js +85 -85
  137. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.4-Basics_Select.js +42 -42
  138. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.5-Basics_Find.js +40 -40
  139. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.6-Basics_Callmap.js +54 -54
  140. package/resources/jsbuilder/JS_AST/JS_AST_Node_4.0-Index_Indexes.js +45 -45
  141. package/resources/jsbuilder/JS_AST/JS_AST_Node_4.1-Index.js +343 -343
  142. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.0-Category.js +38 -38
  143. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.1-Category_Identifier.js +30 -30
  144. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.2-Category_Literal.js +28 -28
  145. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.3-Category_Expression.js +26 -26
  146. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.4-Category_Pattern.js +8 -8
  147. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.5-Category_Declaration.js +43 -43
  148. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.6-Category_Statement.js +21 -21
  149. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.0-Type.js +89 -89
  150. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.1-Type_Class_Declaration.js +8 -8
  151. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.2-Type_Variable_Declaration.js +27 -27
  152. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.3-Type_Variable_Declarator.js +28 -28
  153. package/resources/jsbuilder/JS_AST/JS_AST_Node_7-Query.js +736 -736
  154. package/resources/jsbuilder/JS_AST/JS_AST_Node_8-Features.js +64 -64
  155. package/resources/jsbuilder/JS_AST/JS_AST_Node_9-Planning.js +31 -31
  156. package/resources/jsbuilder/JS_AST/JS_AST_Node_Arrangement.js +15 -15
  157. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Declared_Object.js +305 -305
  158. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature.js +77 -77
  159. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declaration.js +248 -248
  160. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declarator.js +138 -138
  161. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature.js +10 -10
  162. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exported.js +100 -100
  163. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exports.js +60 -60
  164. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Interpreted.js +179 -179
  165. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/_JSGUI_Root_Node_Interpreted.js +43 -43
  166. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/special_case_objectassign_to_object.js +12 -12
  167. package/resources/jsbuilder/JS_AST/JS_AST_Node_Group.js +35 -35
  168. package/resources/jsbuilder/JS_AST/JS_AST_Operation.js +11 -11
  169. package/resources/jsbuilder/JS_AST/JS_AST_Operation_On_Relationship.js +31 -31
  170. package/resources/jsbuilder/JS_AST/JS_AST_Ordered_Relationship_Node_To_Group.js +37 -37
  171. package/resources/jsbuilder/JS_AST/JS_AST_Ordinal.js +39 -39
  172. package/resources/jsbuilder/JS_AST/JS_AST_Ordinal_Relationship.js +25 -25
  173. package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_To_Group.js +200 -200
  174. package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_Within_Group_To_Node.js +43 -43
  175. package/resources/jsbuilder/JS_AST/_JS_AST_Node_3.8-Query_Features.js +76 -76
  176. package/resources/jsbuilder/JS_AST/query/enable_array_as_queryable.js +227 -227
  177. package/resources/jsbuilder/JS_AST/query/find_object_keys.js +404 -404
  178. package/resources/jsbuilder/JS_AST/query/node_queries.js +8 -8
  179. package/resources/jsbuilder/JS_AST/query/root_query_identidy.js +11 -11
  180. package/resources/jsbuilder/JS_AST_Node_Extended/JSGUI_Singular_Declaration.js +85 -85
  181. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Declaration.js +123 -123
  182. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended.js +87 -87
  183. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended_0-Core.js +10 -10
  184. package/resources/jsbuilder/JS_Builder.js +10 -10
  185. package/resources/jsbuilder/JS_File/Feature/JS_File_Declared_Object.js +31 -31
  186. package/resources/jsbuilder/JS_File/Feature/JS_File_Exported_Object_Info.js +25 -25
  187. package/resources/jsbuilder/JS_File/Feature/JS_File_Exports.js +78 -78
  188. package/resources/jsbuilder/JS_File/Feature/JS_File_Feature.js +17 -17
  189. package/resources/jsbuilder/JS_File/Feature/JS_File_Imported_Object_Info.js +25 -25
  190. package/resources/jsbuilder/JS_File/Feature/JS_File_Imports.js +8 -8
  191. package/resources/jsbuilder/JS_File/JS_File.js +12 -12
  192. package/resources/jsbuilder/JS_File/JS_File_0-Core.js +202 -202
  193. package/resources/jsbuilder/JS_File/JS_File_1-Early_Parse.js +175 -175
  194. package/resources/jsbuilder/JS_File/JS_File_2-Babel.js +81 -81
  195. package/resources/jsbuilder/JS_File/JS_File_3-JS_AST_Node.js +86 -86
  196. package/resources/jsbuilder/JS_File/JS_File_4-Query.js +413 -413
  197. package/resources/jsbuilder/JS_File/JS_File_4.1-Query_Features.js +414 -414
  198. package/resources/jsbuilder/JS_File/JS_File_5-Planning.js +59 -59
  199. package/resources/jsbuilder/JS_File/JS_File_6-Changing.js +24 -24
  200. package/resources/jsbuilder/JS_File/JS_File_Export_Reference.js +12 -12
  201. package/resources/jsbuilder/JS_File/JS_File_Import_Reference.js +23 -23
  202. package/resources/jsbuilder/JS_File/JS_File_Import_References.js +31 -31
  203. package/resources/jsbuilder/JS_File/JS_File_Processor.js +16 -16
  204. package/resources/jsbuilder/JS_File/JS_Files.js +15 -15
  205. package/resources/jsbuilder/Module.js +14 -14
  206. package/resources/jsbuilder/Platform.js +13 -13
  207. package/resources/jsbuilder/Platforms.js +69 -69
  208. package/resources/jsbuilder/Project.js +109 -109
  209. package/resources/jsbuilder/Reference.js +1 -1
  210. package/resources/jsbuilder/Reference_Sequence.js +16 -16
  211. package/resources/jsbuilder/Scope.js +29 -29
  212. package/resources/jsbuilder/Variable_Name_Provider.js +42 -42
  213. package/resources/jsbuilder/_JS_File.js +225 -225
  214. package/resources/jsbuilder/ast_query.js +20 -20
  215. package/resources/jsbuilder/babel/babel_consts.js +162 -162
  216. package/resources/jsbuilder/babel/babel_node_tools.js +541 -541
  217. package/resources/jsbuilder/babel/deep_iterate/deep_iterate_babel.js +923 -904
  218. package/resources/jsbuilder/build.js +16 -16
  219. package/resources/jsbuilder/platform_notes.md +66 -66
  220. package/resources/jsbuilder/test/test_ast_node.js +381 -381
  221. package/resources/jsbuilder/test/test_js_file.js +303 -303
  222. package/resources/jsbuilder/test/test_project.js +157 -157
  223. package/resources/local-server-info-resource.js +96 -96
  224. package/resources/notes.txt +10 -10
  225. package/resources/old/website-image-resource.js +1185 -1185
  226. package/resources/process-js.js +498 -498
  227. package/resources/processors/bundlers/bundle.js +29 -29
  228. package/resources/processors/bundlers/bundler.js +23 -23
  229. package/resources/processors/bundlers/css-bundler.js +234 -234
  230. package/resources/processors/bundlers/js/JS_Bundler.js +51 -51
  231. package/resources/processors/bundlers/js/esbuild/Advanced_JS_Bundler_Using_ESBuild.js +388 -391
  232. package/resources/processors/bundlers/js/esbuild/Bundler_Using_ESBuild.js +8 -8
  233. package/resources/processors/bundlers/js/esbuild/Core_JS_Non_Minifying_Bundler_Using_ESBuild.js +188 -188
  234. package/resources/processors/bundlers/js/esbuild/Core_JS_Single_File_Minifying_Bundler_Using_ESBuild.js +191 -192
  235. package/resources/processors/bundlers/js/esbuild/_Old_CSS_Extractor.js +239 -239
  236. package/resources/processors/bundlers/js-bundler.js +263 -263
  237. package/resources/processors/bundlers/test_ast.js +73 -73
  238. package/resources/processors/bundlers/webpage-bundler.js +404 -404
  239. package/resources/processors/bundlers/website-bundler.js +22 -22
  240. package/resources/processors/extractors/Extractor.js +9 -11
  241. package/resources/processors/extractors/js/css_and_js/AST_Node/CSS_And_JS_From_JS_String_Using_AST_Node_Extractor.js +239 -254
  242. package/resources/processors/extractors/js/css_and_js/CSS_And_JS_From_JS_String_Extractor.js +3 -3
  243. package/resources/processors/extractors/string/Pos_Span_String_Extractor.js +93 -93
  244. package/resources/server-installed-tools.js +28 -28
  245. package/resources/server-resource-pool.js +41 -41
  246. package/resources/website-audio-resource.js +735 -735
  247. package/resources/website-css-resource.js +411 -411
  248. package/resources/website-image-resource.js +412 -412
  249. package/resources/website-javascript-resource-processor.js +908 -908
  250. package/resources/website-javascript-resource.js +874 -874
  251. package/resources/website-resource-processor.js +10 -10
  252. package/resources/website-resource.js +164 -164
  253. package/resources/website-static-html-resource.js +199 -199
  254. package/resources/website-template-html-resource.js +231 -231
  255. package/roadmap.md +75 -75
  256. package/server.js +609 -573
  257. package/static-page-context.js +13 -13
  258. package/website/webpage.js +81 -81
  259. package/website/website-group.js +15 -15
  260. package/website/website.js +260 -260
  261. package/examples/controls/11d) window, shared model mirrored integer text fields/both.js +0 -17
  262. package/examples/controls/13) window, shared model mirrored lat_long/client.js +0 -933
  263. package/examples/controls/13) window, shared model mirrored lat_long/server.js +0 -50
  264. package/examples/controls/14) window, control compositional model/client.js +0 -328
  265. package/examples/controls/14) window, control compositional model/server.js +0 -118
  266. package/examples/controls/14a) window, control spec has compositional model/client.js +0 -440
  267. package/examples/controls/14a) window, control spec has compositional model/server.js +0 -118
  268. package/examples/controls/15) window, text field/client.js +0 -256
  269. package/examples/controls/15) window, text field/server.js +0 -39
  270. package/examples/controls/16) Window([Text_Input])/client.js +0 -266
  271. package/examples/controls/16) Window([Text_Input])/server.js +0 -109
  272. package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/client.js +0 -494
  273. package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/isomorphic.js +0 -24
  274. package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/server.js +0 -73
  275. package/examples/controls/2b) two window, context menus/client.js +0 -193
  276. package/examples/controls/2b) two window, context menus/server.js +0 -114
  277. package/examples/controls/4a) window, tabbed panel with various controls inside/client.js +0 -233
  278. package/examples/controls/4a) window, tabbed panel with various controls inside/server.js +0 -118
@@ -1,507 +1,507 @@
1
- /**
2
- * Created by James on 29/07/2014.
3
- */
4
-
5
- // 2022 - Seems a little uncertain about what it is for, and what it does has grown over time.
6
-
7
-
8
-
9
- // A Website abstraction and a Website_Publisher seem like a good way forward.
10
-
11
-
12
- // Want to make a near future release have a web publishing system that is easier to use as well as more
13
- // powerful.
14
-
15
- // Publishing static sites, rendering and compiling.
16
-
17
- // Represents (and is?) a website itself, and its representation available through the Resource system.
18
-
19
-
20
- // Want to get the core resources working and tested.
21
- // Want to run a clock website / service to start with.
22
- // The server could have a clock, while clients could connect to it and share the information.
23
- // Could also experiment with P2P distribution of the data.
24
- // A clock is also useful because it contains time signals so we can see how long it takes for data to reach various machines.
25
-
26
- // A web resource in particular?
27
- // Any need for an HTML resource?
28
- // Probably not - have web resource handle HTML and websockets.
29
-
30
- // Resources could also have events which objects can listen to.
31
- // Programmatic objects can listen.
32
- // The resources may broadcast to whatever is listening.
33
-
34
- // Also, maintaining one connection stream, communicating with multiple resources - could connect through a Resource Pool, or maybe there
35
- // could be a Multi Resource Publisher that publishes a bunch of resources.
36
-
37
- // The Application router at the moment sending requests to resources.
38
- // I am thinking that rather than doing that, the requests should be handled by a resource publisher that interacts with the resource and publishes it over HTTP.
39
-
40
- // Resources in general won't handle HTTP requests, though they will have the capability.
41
- // More likely that a resource, when it is served online, will be served using a Resource Publisher (which is itself a resource), which handles HTTP implementation details that would otherwise have
42
- // to be repeated between resources.
43
-
44
- //define(["./jsgui-lang-util", './abstract-resource'], function(jsgui, AR) {
45
-
46
- // Do this not with AMD?
47
-
48
- // May need Website_Data_Resource
49
- // Would be configured within the node app, client has maximum autoconfig from connecting to the server, and integration with client-side controls.
50
- // With the DB admin, it's about returining queries (maybe from RAM) about table data.
51
- // /data/then the api?
52
-
53
- // Respond to both data HTTP requests and websocket connections.
54
-
55
- // HTTP data request -> response seems like the most important step now.
56
-
57
- // An fs Resource would be of use for file system browser.
58
- // Could have a client-side fs resource that connects to a veriety of services, could have one that connects to the server-side fs resource.
59
-
60
- // Need to connect a data-providing resource to the UI component in cases where it's not secure to do so automatically.
61
- // It would be much more secure to bring up an NTP provision service automatically than a file system one. Don't want to take that risk now.
62
- //
63
-
64
- // Possibly WebPack could be considered such a resource? Or find a different type for that type of resource?
65
-
66
- // Compilation_Resource and Compiler_Resource...
67
-
68
-
69
- // Maybe should do more to represent a website on a server.
70
- // Maybe it needs more docs, being rather critical.
71
-
72
-
73
-
74
-
75
- var Site_Images = require("./website-image-resource");
76
-
77
- //console.log('1) Site_Images', Site_Images);
78
-
79
- var jsgui = require("jsgui3-html");
80
- const { each, get_a_sig, is_defined, tof } = jsgui;
81
-
82
- //var Web_Resource = require('./website-resource');
83
- const Resource = jsgui.Resource;
84
- const Router = jsgui.Router;
85
- //const Evented_Class = jsgui.Evented_Class;
86
-
87
- const Resource_Pool = require("./server-resource-pool");
88
- //var Resource_Web_Admin = require('../web-admin');
89
-
90
- const Site_JavaScript = require("./website-javascript-resource");
91
- //console.log('1) Site_JavaScript', Site_JavaScript);
92
- const Site_CSS = require("./website-css-resource");
93
- const Site_Static_HTML = require("./website-static-html-resource");
94
- //var DB_Web_Resource = require('../../web/db-resource-postgres');
95
- //var database_resource_factory = require('../../db/resource/factory');
96
-
97
- const Resource_Publisher = require("../publishing/resource-publisher");
98
- const Observable_Publisher = require("../publishing/observable-publisher");
99
- const Function_Publisher = require("../publishing/function-publisher");
100
- //const Data_Resource = require("./data-resource");
101
-
102
- // Proxy_Server_Resource possibly.
103
- // Note that the client should be able to access a Proxy_Server_Resource if needed.
104
- // Could just send request onwards and do same for response.
105
- // Buffering rate-limiting proxies too though?
106
-
107
-
108
- // May help with FirstPoint_Server.
109
-
110
- // Could move the publishing parts to Website_Resource_Publisher perhaps.
111
-
112
-
113
-
114
- // Maybe worth just having a Website object.
115
- // Then the Website_Resource can encapsulate that.
116
-
117
- // Better if this wraps the Website object?
118
-
119
- // A Website has its own Website Resource Pool?
120
-
121
- // Make Website_Resource into the wrapper that wraps Website?
122
- // Or we don't need that, just use HTTP_Website_Publisher.
123
-
124
- // A lot of important functionality here though...
125
- // Creating the various resources to add to the website resource pool on the server.
126
-
127
- // But it's going to be the publishers rather than the resources processing HTTP requests.
128
- // Change of architecture.
129
-
130
-
131
- // Maybe won't need the variety of resources.
132
- // May be simpler to program for.
133
- // Will initially be more compilation & bundling oriented
134
- // Then will send those pieces of data to the relevant HTTP handlers.
135
- // Less wrapped in Resource classes and terminology.
136
- // Will be able to publish functionality as Resource should I want to.
137
-
138
-
139
-
140
-
141
-
142
-
143
-
144
- class Website_Resource extends Resource {
145
- constructor(spec = {}) {
146
-
147
- throw 'Stop - Discontinued - look for alternatives for the moment.';
148
-
149
- super(spec);
150
- // A bit of a special resource here because it has its own resource_pool.
151
- let resource_pool = new Resource_Pool({
152
- name: "Website Resource Pool"
153
- });
154
- this.resource_pool = resource_pool;
155
- let database_spec = spec.database;
156
- let web_database_resource;
157
-
158
- if (database_spec) {
159
- database_spec.name = database_spec.name || database_spec.database_name;
160
- let database_resource = database_resource_factory(database_spec);
161
- database_resource.start();
162
- // should start automatically when in the pool?
163
- // does the pool need to be told to start?
164
- // Though probably don't want to start the resource on initialization.
165
- resource_pool.add(database_resource);
166
- web_database_resource = new DB_Web_Resource({
167
- database: database_resource,
168
- meta: {
169
- name: "Web DB",
170
- pool: resource_pool
171
- }
172
- });
173
- }
174
-
175
- // Quite a generalised interface it seems.
176
- if (web_database_resource) {
177
- resource_pool.add(web_database_resource);
178
- }
179
-
180
- var router = new Router({
181
- name: "Site Router"
182
- });
183
-
184
- this.router = router;
185
-
186
- var spec_web_admin = {
187
- //'web_database': web_database_resource,
188
- meta: {
189
- name: "Web Admin"
190
- }
191
-
192
- };
193
- // Possibly run web admin from within the web resource itself?
194
- // The web admin could use its own website resource.
195
-
196
- //if (web_database_resource) {
197
- // spec_web_admin.web_database = web_database_resource;
198
- //}
199
-
200
- var img_resource = new Site_Images({
201
- //'meta': {
202
- name: "Site Images",
203
- pool: resource_pool
204
- // }
205
- });
206
-
207
- // Seems like site JS is / will use a compilation resource.
208
-
209
- var js_resource = new Site_JavaScript({
210
- //'meta': {
211
- name: "Site JavaScript",
212
- pool: resource_pool
213
- //}
214
- });
215
-
216
- // Also want a static HTML server.
217
- // Would serve index.html by default I think???
218
- // Probably with the static or simplest settings.
219
-
220
- var static_html_resource;
221
-
222
- if (spec === "static") {
223
- static_html_resource = new Site_Static_HTML({
224
- //'meta': {
225
- name: "Static HTML",
226
- pool: resource_pool
227
- //}
228
- });
229
- resource_pool.push(static_html_resource);
230
- // Perhaps set it up with the specific files (automatically)?
231
- // Probably with the index.html
232
- }
233
- var css_resource = new Site_CSS({
234
- //'meta': {
235
- name: "Site CSS",
236
- pool: resource_pool
237
- //}
238
- });
239
-
240
- js_resource.on('extracted-controls-css', str_extracted_css => {
241
- css_resource.serve_str_css('controls.css', str_extracted_css);
242
- // Will serve this as controls.css
243
- // Separate HTTP request, will get more CSS for the moment.
244
-
245
- });
246
-
247
-
248
- // And this can make a few other resources, like the compilation resource.
249
- // Website resource could include compilation resources?
250
- // But maybe they will be included on the server
251
- // May need some processor rationing with compilations taking place.
252
-
253
-
254
- // javascript and css resources.
255
- resource_pool.push(router);
256
- resource_pool.push(img_resource);
257
- resource_pool.push(js_resource);
258
- resource_pool.push(css_resource);
259
- //resource_pool.push(data_resource);
260
-
261
- // anything ending in .css as well.
262
- // Routing maybe wouldn't work like that.
263
- //router.set_route('*.css', css_resource, css_resource.process);
264
-
265
- router.set_route("css/*", css_resource, css_resource.process);
266
- router.set_route("js/*", js_resource, js_resource.process);
267
- // As well as this, it could get the JavaScript resource to serve the JavaScript from the app's js directory.
268
- js_resource.serve_directory("js");
269
- router.set_route("i/*", img_resource, img_resource.process);
270
- router.set_route("img/*", img_resource, img_resource.process);
271
- router.set_route("imgs/*", img_resource, img_resource.process);
272
- router.set_route("images/*", img_resource, img_resource.process);
273
- this.map_resource_publishers = this.map_resource_publishers || {};
274
- router.set_route("resources/:resource_name/*", this, (req, res) => {
275
- let { url, method } = req;
276
- let s_url = url.split("/");
277
- let resource_short_name = s_url[2];
278
- let resource_publisher = this.map_resource_publishers[resource_short_name];
279
- if (resource_publisher) {
280
- resource_publisher.handle_http(req, res);
281
- }
282
- });
283
- if (!is_defined(spec)) spec = {};
284
- this.resource_pool = resource_pool;
285
- }
286
-
287
- publishing_get_pub(item) {
288
- let pub;
289
- if (item instanceof jsgui.Resource) {
290
- pub = new Resource_Publisher({
291
- resource: item
292
- });
293
- } else {
294
- // if its a function
295
- // return that function call to the response.
296
- let t_item = typeof item;
297
- if (t_item === "function") {
298
- // Function_Call_Publisher
299
- // could respec this.
300
- // And the Function_Publisher operates through the Publisher API. Not sure what that is right now though.
301
-
302
- pub = new Function_Publisher({
303
- fn: item
304
- });
305
- //this.map_resource_publishers[published_name] = pub;
306
- //
307
- } else {
308
- if (item.next && item.complete && item.error) {
309
- // assuming observable
310
- // Observable publisher
311
- // One way sending...
312
- //console.log('using Observable_Publisher');
313
- pub = new Observable_Publisher({
314
- obs: item
315
- });
316
- // or not a resource publisher, an observable publisher.
317
- //this.map_resource_publishers = this.map_resource_publishers || {};
318
- //this.map_resource_publishers[published_name] = obs_pub;
319
-
320
- //console.log('2) this', this);
321
- //console.log('this.map_resource_publishers', this.map_resource_publishers);
322
- //console.trace();
323
- } else {
324
- console.log("item", item);
325
- throw "Unrecognised item type. Possibly node module versions are wrong / have not been linked fully.";
326
- }
327
- }
328
- //if (item instanceof Evented_Class) {
329
- }
330
- return pub;
331
- }
332
-
333
- // publish within resources?
334
- publish(published_name, item, schema) {
335
- let sig = get_a_sig(arguments),
336
- a = arguments,
337
- l = a.length;
338
- const single = (published_name, item) => {
339
- if (item instanceof jsgui.Resource) {
340
- let resource_publisher = new Resource_Publisher({
341
- resource: item,
342
- name: published_name
343
- });
344
- this.map_resource_publishers[published_name] = resource_publisher;
345
-
346
- item.name = item.name || published_name;
347
- // add that resource!
348
- // (to the pool?)
349
- //console.log('item', item);
350
- this.resource_pool.add(item);
351
-
352
- //console.log('Object.keys(this.map_resource_publishers)', Object.keys(this.map_resource_publishers));
353
- } else {
354
- // if its a function
355
- // return that function call to the response.
356
- let t_item = typeof item;
357
- if (t_item === "function") {
358
- // Function_Call_Publisher
359
- // could respec this.
360
-
361
- // And the Function_Publisher operates through the Publisher API. Not sure what that is right now though.
362
- // directly attaching the resource publishers?
363
- let pub = new Function_Publisher({
364
- fn: item,
365
- schema: schema
366
- });
367
- this.map_resource_publishers[published_name] = pub;
368
- //
369
-
370
- } else {
371
- if (item.next && item.complete && item.error) {
372
- let obs_pub = new Observable_Publisher({
373
- obs: item,
374
- schema: schema
375
- });
376
- this.map_resource_publishers[published_name] = obs_pub;
377
- } else {
378
- console.log("item", item);
379
- throw "Unrecognised item type. Possibly node module versions are wrong / have not been linked fully.";
380
- }
381
- }
382
- //if (item instanceof Evented_Class) {
383
- }
384
- };
385
-
386
- if (sig === "[o]") {
387
- each(a[0], (v, i) => {
388
- single(i, v);
389
- })
390
- } else {
391
-
392
- single(published_name, item);
393
- }
394
- }
395
-
396
- get resource_names() {
397
- //console.log('this.resource_pool', this.resource_pool);
398
- return this.resource_pool.resource_names;
399
- }
400
-
401
- get_resource(resource_name) {
402
- var resource_pool = this.resource_pool;
403
- return resource_pool.get_resource(resource_name);
404
- }
405
-
406
- get def_resource_publishers() {
407
- const res = {};
408
- each(this.map_resource_publishers, (rp, name) => {
409
-
410
- let def = {
411
- name: name,
412
- type: rp.type
413
- }
414
- res[name] = def;
415
- if (rp.type === 'function') {
416
- if (rp.schema) def.schema = rp.schema;
417
- }
418
- });
419
- return res;
420
- }
421
-
422
- start(callback) {
423
- var resource_pool = this.resource_pool;
424
- resource_pool.start(callback);
425
- }
426
-
427
- meets_requirements() {
428
- // Likely will be part of Status
429
-
430
- //return false;
431
-
432
- return true;
433
- }
434
-
435
- // Needs to be able to process HTTP requests. A bit like the Router in that way.
436
- process(req, res) {
437
- //console.log('website process request req.url', req.url);
438
- //throw 'stop';
439
-
440
- var remoteAddress = req.connection.remoteAddress;
441
- var router = this.router;
442
- var res_process = router.process(req, res);
443
-
444
- // Likely will need to make this more advanced, possibly to suit a spec.
445
- // Website_Resource_Publisher may be the best place to deal with this.
446
-
447
- // Gives it to the router to process.
448
- // Possibly we need a Control_Publisher?
449
- // To publish a Control at an address on the web.
450
-
451
- console.log('Website_Resource !!res_process', !!res_process);
452
-
453
- // Need more HTTP request to response handlers.
454
- // Or just HTTP handlers really.
455
- // They may be best accessed by the router though.
456
- // Make a decent function abstraction for them next time I need an HTTP handler.
457
-
458
-
459
-
460
-
461
-
462
-
463
-
464
-
465
-
466
- if (res_process === false) {
467
- if (req.url === "/") {
468
- // Seems like too much of a special case.
469
-
470
- // Send this to the static HTML processing system.
471
-
472
- /*
473
-
474
- var static_html_resource = this.resource_pool.get_resource(
475
- "Static HTML"
476
- );
477
- //console.log('static_html_resource', static_html_resource);
478
- // And lets get the static resource to process it
479
- if (static_html_resource) {
480
- static_html_resource.process(req, res);
481
- }
482
- */
483
-
484
- // Show the default page. ???
485
-
486
- //console.log('deprecated functionality');
487
- //throw 'stop';
488
-
489
- res.writeHead(404, {
490
- "Content-Type": "text/plain"
491
- });
492
- res.write("404 Not Found\n");
493
- res.end();
494
-
495
- } else {
496
- // show a 404
497
- res.writeHead(404, {
498
- "Content-Type": "text/plain"
499
- });
500
- res.write("404 Not Found\n");
501
- res.end();
502
- }
503
- }
504
- }
505
- }
506
-
507
- module.exports = Website_Resource;
1
+ /**
2
+ * Created by James on 29/07/2014.
3
+ */
4
+
5
+ // 2022 - Seems a little uncertain about what it is for, and what it does has grown over time.
6
+
7
+
8
+
9
+ // A Website abstraction and a Website_Publisher seem like a good way forward.
10
+
11
+
12
+ // Want to make a near future release have a web publishing system that is easier to use as well as more
13
+ // powerful.
14
+
15
+ // Publishing static sites, rendering and compiling.
16
+
17
+ // Represents (and is?) a website itself, and its representation available through the Resource system.
18
+
19
+
20
+ // Want to get the core resources working and tested.
21
+ // Want to run a clock website / service to start with.
22
+ // The server could have a clock, while clients could connect to it and share the information.
23
+ // Could also experiment with P2P distribution of the data.
24
+ // A clock is also useful because it contains time signals so we can see how long it takes for data to reach various machines.
25
+
26
+ // A web resource in particular?
27
+ // Any need for an HTML resource?
28
+ // Probably not - have web resource handle HTML and websockets.
29
+
30
+ // Resources could also have events which objects can listen to.
31
+ // Programmatic objects can listen.
32
+ // The resources may broadcast to whatever is listening.
33
+
34
+ // Also, maintaining one connection stream, communicating with multiple resources - could connect through a Resource Pool, or maybe there
35
+ // could be a Multi Resource Publisher that publishes a bunch of resources.
36
+
37
+ // The Application router at the moment sending requests to resources.
38
+ // I am thinking that rather than doing that, the requests should be handled by a resource publisher that interacts with the resource and publishes it over HTTP.
39
+
40
+ // Resources in general won't handle HTTP requests, though they will have the capability.
41
+ // More likely that a resource, when it is served online, will be served using a Resource Publisher (which is itself a resource), which handles HTTP implementation details that would otherwise have
42
+ // to be repeated between resources.
43
+
44
+ //define(["./jsgui-lang-util", './abstract-resource'], function(jsgui, AR) {
45
+
46
+ // Do this not with AMD?
47
+
48
+ // May need Website_Data_Resource
49
+ // Would be configured within the node app, client has maximum autoconfig from connecting to the server, and integration with client-side controls.
50
+ // With the DB admin, it's about returining queries (maybe from RAM) about table data.
51
+ // /data/then the api?
52
+
53
+ // Respond to both data HTTP requests and websocket connections.
54
+
55
+ // HTTP data request -> response seems like the most important step now.
56
+
57
+ // An fs Resource would be of use for file system browser.
58
+ // Could have a client-side fs resource that connects to a veriety of services, could have one that connects to the server-side fs resource.
59
+
60
+ // Need to connect a data-providing resource to the UI component in cases where it's not secure to do so automatically.
61
+ // It would be much more secure to bring up an NTP provision service automatically than a file system one. Don't want to take that risk now.
62
+ //
63
+
64
+ // Possibly WebPack could be considered such a resource? Or find a different type for that type of resource?
65
+
66
+ // Compilation_Resource and Compiler_Resource...
67
+
68
+
69
+ // Maybe should do more to represent a website on a server.
70
+ // Maybe it needs more docs, being rather critical.
71
+
72
+
73
+
74
+
75
+ var Site_Images = require("./website-image-resource");
76
+
77
+ //console.log('1) Site_Images', Site_Images);
78
+
79
+ var jsgui = require("jsgui3-html");
80
+ const { each, get_a_sig, is_defined, tof } = jsgui;
81
+
82
+ //var Web_Resource = require('./website-resource');
83
+ const Resource = jsgui.Resource;
84
+ const Router = jsgui.Router;
85
+ //const Evented_Class = jsgui.Evented_Class;
86
+
87
+ const Resource_Pool = require("./server-resource-pool");
88
+ //var Resource_Web_Admin = require('../web-admin');
89
+
90
+ const Site_JavaScript = require("./website-javascript-resource");
91
+ //console.log('1) Site_JavaScript', Site_JavaScript);
92
+ const Site_CSS = require("./website-css-resource");
93
+ const Site_Static_HTML = require("./website-static-html-resource");
94
+ //var DB_Web_Resource = require('../../web/db-resource-postgres');
95
+ //var database_resource_factory = require('../../db/resource/factory');
96
+
97
+ const Resource_Publisher = require("../publishing/resource-publisher");
98
+ const Observable_Publisher = require("../publishing/observable-publisher");
99
+ const Function_Publisher = require("../publishing/function-publisher");
100
+ //const Data_Resource = require("./data-resource");
101
+
102
+ // Proxy_Server_Resource possibly.
103
+ // Note that the client should be able to access a Proxy_Server_Resource if needed.
104
+ // Could just send request onwards and do same for response.
105
+ // Buffering rate-limiting proxies too though?
106
+
107
+
108
+ // May help with FirstPoint_Server.
109
+
110
+ // Could move the publishing parts to Website_Resource_Publisher perhaps.
111
+
112
+
113
+
114
+ // Maybe worth just having a Website object.
115
+ // Then the Website_Resource can encapsulate that.
116
+
117
+ // Better if this wraps the Website object?
118
+
119
+ // A Website has its own Website Resource Pool?
120
+
121
+ // Make Website_Resource into the wrapper that wraps Website?
122
+ // Or we don't need that, just use HTTP_Website_Publisher.
123
+
124
+ // A lot of important functionality here though...
125
+ // Creating the various resources to add to the website resource pool on the server.
126
+
127
+ // But it's going to be the publishers rather than the resources processing HTTP requests.
128
+ // Change of architecture.
129
+
130
+
131
+ // Maybe won't need the variety of resources.
132
+ // May be simpler to program for.
133
+ // Will initially be more compilation & bundling oriented
134
+ // Then will send those pieces of data to the relevant HTTP handlers.
135
+ // Less wrapped in Resource classes and terminology.
136
+ // Will be able to publish functionality as Resource should I want to.
137
+
138
+
139
+
140
+
141
+
142
+
143
+
144
+ class Website_Resource extends Resource {
145
+ constructor(spec = {}) {
146
+
147
+ throw 'Stop - Discontinued - look for alternatives for the moment.';
148
+
149
+ super(spec);
150
+ // A bit of a special resource here because it has its own resource_pool.
151
+ let resource_pool = new Resource_Pool({
152
+ name: "Website Resource Pool"
153
+ });
154
+ this.resource_pool = resource_pool;
155
+ let database_spec = spec.database;
156
+ let web_database_resource;
157
+
158
+ if (database_spec) {
159
+ database_spec.name = database_spec.name || database_spec.database_name;
160
+ let database_resource = database_resource_factory(database_spec);
161
+ database_resource.start();
162
+ // should start automatically when in the pool?
163
+ // does the pool need to be told to start?
164
+ // Though probably don't want to start the resource on initialization.
165
+ resource_pool.add(database_resource);
166
+ web_database_resource = new DB_Web_Resource({
167
+ database: database_resource,
168
+ meta: {
169
+ name: "Web DB",
170
+ pool: resource_pool
171
+ }
172
+ });
173
+ }
174
+
175
+ // Quite a generalised interface it seems.
176
+ if (web_database_resource) {
177
+ resource_pool.add(web_database_resource);
178
+ }
179
+
180
+ var router = new Router({
181
+ name: "Site Router"
182
+ });
183
+
184
+ this.router = router;
185
+
186
+ var spec_web_admin = {
187
+ //'web_database': web_database_resource,
188
+ meta: {
189
+ name: "Web Admin"
190
+ }
191
+
192
+ };
193
+ // Possibly run web admin from within the web resource itself?
194
+ // The web admin could use its own website resource.
195
+
196
+ //if (web_database_resource) {
197
+ // spec_web_admin.web_database = web_database_resource;
198
+ //}
199
+
200
+ var img_resource = new Site_Images({
201
+ //'meta': {
202
+ name: "Site Images",
203
+ pool: resource_pool
204
+ // }
205
+ });
206
+
207
+ // Seems like site JS is / will use a compilation resource.
208
+
209
+ var js_resource = new Site_JavaScript({
210
+ //'meta': {
211
+ name: "Site JavaScript",
212
+ pool: resource_pool
213
+ //}
214
+ });
215
+
216
+ // Also want a static HTML server.
217
+ // Would serve index.html by default I think???
218
+ // Probably with the static or simplest settings.
219
+
220
+ var static_html_resource;
221
+
222
+ if (spec === "static") {
223
+ static_html_resource = new Site_Static_HTML({
224
+ //'meta': {
225
+ name: "Static HTML",
226
+ pool: resource_pool
227
+ //}
228
+ });
229
+ resource_pool.push(static_html_resource);
230
+ // Perhaps set it up with the specific files (automatically)?
231
+ // Probably with the index.html
232
+ }
233
+ var css_resource = new Site_CSS({
234
+ //'meta': {
235
+ name: "Site CSS",
236
+ pool: resource_pool
237
+ //}
238
+ });
239
+
240
+ js_resource.on('extracted-controls-css', str_extracted_css => {
241
+ css_resource.serve_str_css('controls.css', str_extracted_css);
242
+ // Will serve this as controls.css
243
+ // Separate HTTP request, will get more CSS for the moment.
244
+
245
+ });
246
+
247
+
248
+ // And this can make a few other resources, like the compilation resource.
249
+ // Website resource could include compilation resources?
250
+ // But maybe they will be included on the server
251
+ // May need some processor rationing with compilations taking place.
252
+
253
+
254
+ // javascript and css resources.
255
+ resource_pool.push(router);
256
+ resource_pool.push(img_resource);
257
+ resource_pool.push(js_resource);
258
+ resource_pool.push(css_resource);
259
+ //resource_pool.push(data_resource);
260
+
261
+ // anything ending in .css as well.
262
+ // Routing maybe wouldn't work like that.
263
+ //router.set_route('*.css', css_resource, css_resource.process);
264
+
265
+ router.set_route("css/*", css_resource, css_resource.process);
266
+ router.set_route("js/*", js_resource, js_resource.process);
267
+ // As well as this, it could get the JavaScript resource to serve the JavaScript from the app's js directory.
268
+ js_resource.serve_directory("js");
269
+ router.set_route("i/*", img_resource, img_resource.process);
270
+ router.set_route("img/*", img_resource, img_resource.process);
271
+ router.set_route("imgs/*", img_resource, img_resource.process);
272
+ router.set_route("images/*", img_resource, img_resource.process);
273
+ this.map_resource_publishers = this.map_resource_publishers || {};
274
+ router.set_route("resources/:resource_name/*", this, (req, res) => {
275
+ let { url, method } = req;
276
+ let s_url = url.split("/");
277
+ let resource_short_name = s_url[2];
278
+ let resource_publisher = this.map_resource_publishers[resource_short_name];
279
+ if (resource_publisher) {
280
+ resource_publisher.handle_http(req, res);
281
+ }
282
+ });
283
+ if (!is_defined(spec)) spec = {};
284
+ this.resource_pool = resource_pool;
285
+ }
286
+
287
+ publishing_get_pub(item) {
288
+ let pub;
289
+ if (item instanceof jsgui.Resource) {
290
+ pub = new Resource_Publisher({
291
+ resource: item
292
+ });
293
+ } else {
294
+ // if its a function
295
+ // return that function call to the response.
296
+ let t_item = typeof item;
297
+ if (t_item === "function") {
298
+ // Function_Call_Publisher
299
+ // could respec this.
300
+ // And the Function_Publisher operates through the Publisher API. Not sure what that is right now though.
301
+
302
+ pub = new Function_Publisher({
303
+ fn: item
304
+ });
305
+ //this.map_resource_publishers[published_name] = pub;
306
+ //
307
+ } else {
308
+ if (item.next && item.complete && item.error) {
309
+ // assuming observable
310
+ // Observable publisher
311
+ // One way sending...
312
+ //console.log('using Observable_Publisher');
313
+ pub = new Observable_Publisher({
314
+ obs: item
315
+ });
316
+ // or not a resource publisher, an observable publisher.
317
+ //this.map_resource_publishers = this.map_resource_publishers || {};
318
+ //this.map_resource_publishers[published_name] = obs_pub;
319
+
320
+ //console.log('2) this', this);
321
+ //console.log('this.map_resource_publishers', this.map_resource_publishers);
322
+ //console.trace();
323
+ } else {
324
+ console.log("item", item);
325
+ throw "Unrecognised item type. Possibly node module versions are wrong / have not been linked fully.";
326
+ }
327
+ }
328
+ //if (item instanceof Evented_Class) {
329
+ }
330
+ return pub;
331
+ }
332
+
333
+ // publish within resources?
334
+ publish(published_name, item, schema) {
335
+ let sig = get_a_sig(arguments),
336
+ a = arguments,
337
+ l = a.length;
338
+ const single = (published_name, item) => {
339
+ if (item instanceof jsgui.Resource) {
340
+ let resource_publisher = new Resource_Publisher({
341
+ resource: item,
342
+ name: published_name
343
+ });
344
+ this.map_resource_publishers[published_name] = resource_publisher;
345
+
346
+ item.name = item.name || published_name;
347
+ // add that resource!
348
+ // (to the pool?)
349
+ //console.log('item', item);
350
+ this.resource_pool.add(item);
351
+
352
+ //console.log('Object.keys(this.map_resource_publishers)', Object.keys(this.map_resource_publishers));
353
+ } else {
354
+ // if its a function
355
+ // return that function call to the response.
356
+ let t_item = typeof item;
357
+ if (t_item === "function") {
358
+ // Function_Call_Publisher
359
+ // could respec this.
360
+
361
+ // And the Function_Publisher operates through the Publisher API. Not sure what that is right now though.
362
+ // directly attaching the resource publishers?
363
+ let pub = new Function_Publisher({
364
+ fn: item,
365
+ schema: schema
366
+ });
367
+ this.map_resource_publishers[published_name] = pub;
368
+ //
369
+
370
+ } else {
371
+ if (item.next && item.complete && item.error) {
372
+ let obs_pub = new Observable_Publisher({
373
+ obs: item,
374
+ schema: schema
375
+ });
376
+ this.map_resource_publishers[published_name] = obs_pub;
377
+ } else {
378
+ console.log("item", item);
379
+ throw "Unrecognised item type. Possibly node module versions are wrong / have not been linked fully.";
380
+ }
381
+ }
382
+ //if (item instanceof Evented_Class) {
383
+ }
384
+ };
385
+
386
+ if (sig === "[o]") {
387
+ each(a[0], (v, i) => {
388
+ single(i, v);
389
+ })
390
+ } else {
391
+
392
+ single(published_name, item);
393
+ }
394
+ }
395
+
396
+ get resource_names() {
397
+ //console.log('this.resource_pool', this.resource_pool);
398
+ return this.resource_pool.resource_names;
399
+ }
400
+
401
+ get_resource(resource_name) {
402
+ var resource_pool = this.resource_pool;
403
+ return resource_pool.get_resource(resource_name);
404
+ }
405
+
406
+ get def_resource_publishers() {
407
+ const res = {};
408
+ each(this.map_resource_publishers, (rp, name) => {
409
+
410
+ let def = {
411
+ name: name,
412
+ type: rp.type
413
+ }
414
+ res[name] = def;
415
+ if (rp.type === 'function') {
416
+ if (rp.schema) def.schema = rp.schema;
417
+ }
418
+ });
419
+ return res;
420
+ }
421
+
422
+ start(callback) {
423
+ var resource_pool = this.resource_pool;
424
+ resource_pool.start(callback);
425
+ }
426
+
427
+ meets_requirements() {
428
+ // Likely will be part of Status
429
+
430
+ //return false;
431
+
432
+ return true;
433
+ }
434
+
435
+ // Needs to be able to process HTTP requests. A bit like the Router in that way.
436
+ process(req, res) {
437
+ //console.log('website process request req.url', req.url);
438
+ //throw 'stop';
439
+
440
+ var remoteAddress = req.connection.remoteAddress;
441
+ var router = this.router;
442
+ var res_process = router.process(req, res);
443
+
444
+ // Likely will need to make this more advanced, possibly to suit a spec.
445
+ // Website_Resource_Publisher may be the best place to deal with this.
446
+
447
+ // Gives it to the router to process.
448
+ // Possibly we need a Control_Publisher?
449
+ // To publish a Control at an address on the web.
450
+
451
+ console.log('Website_Resource !!res_process', !!res_process);
452
+
453
+ // Need more HTTP request to response handlers.
454
+ // Or just HTTP handlers really.
455
+ // They may be best accessed by the router though.
456
+ // Make a decent function abstraction for them next time I need an HTTP handler.
457
+
458
+
459
+
460
+
461
+
462
+
463
+
464
+
465
+
466
+ if (res_process === false) {
467
+ if (req.url === "/") {
468
+ // Seems like too much of a special case.
469
+
470
+ // Send this to the static HTML processing system.
471
+
472
+ /*
473
+
474
+ var static_html_resource = this.resource_pool.get_resource(
475
+ "Static HTML"
476
+ );
477
+ //console.log('static_html_resource', static_html_resource);
478
+ // And lets get the static resource to process it
479
+ if (static_html_resource) {
480
+ static_html_resource.process(req, res);
481
+ }
482
+ */
483
+
484
+ // Show the default page. ???
485
+
486
+ //console.log('deprecated functionality');
487
+ //throw 'stop';
488
+
489
+ res.writeHead(404, {
490
+ "Content-Type": "text/plain"
491
+ });
492
+ res.write("404 Not Found\n");
493
+ res.end();
494
+
495
+ } else {
496
+ // show a 404
497
+ res.writeHead(404, {
498
+ "Content-Type": "text/plain"
499
+ });
500
+ res.write("404 Not Found\n");
501
+ res.end();
502
+ }
503
+ }
504
+ }
505
+ }
506
+
507
+ module.exports = Website_Resource;