jsgui3-server 0.0.121 → 0.0.123

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 (282) 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 +112 -248
  16. package/examples/box/2) twenty square boxes/css flex wrap/server.js +39 -112
  17. package/examples/box/3) twenty selectable square boxes/css flex wrap/client.js +129 -0
  18. package/examples/{controls/15) window, text field → box/3) twenty selectable square boxes/css flex wrap}/server.js +38 -38
  19. package/examples/boxes/square_boxes.js +45 -48
  20. package/examples/boxes/square_boxes_client.js +132 -136
  21. package/examples/client-side-popup-menu-button.html +93 -93
  22. package/examples/color_palette.js +51 -51
  23. package/examples/color_palette_client.js +95 -95
  24. package/examples/controls/1) window/client.js +186 -186
  25. package/examples/controls/1) window/server.js +117 -117
  26. package/examples/controls/10) window, mirrored text inputs/client.js +118 -320
  27. package/examples/controls/10) window, mirrored text inputs/server.js +37 -117
  28. package/examples/controls/11) window, mirrored text fields/client.js +493 -251
  29. package/examples/controls/11) window, mirrored text fields/server.js +117 -117
  30. package/examples/controls/11b) window, shared Data_Object model mirrored text fields/client.js +613 -331
  31. package/examples/controls/11b) window, shared Data_Object model mirrored text fields/server.js +117 -117
  32. package/examples/controls/11c) window, shared Data_Value model mirrored text fields/client.js +617 -617
  33. package/examples/controls/11c) window, shared Data_Value model mirrored text fields/server.js +117 -117
  34. package/examples/controls/11d) window, shared model mirrored integer text fields/client.js +611 -280
  35. package/examples/controls/11d) window, shared model mirrored integer text fields/server.js +134 -22
  36. package/examples/controls/12) window, Select_Options control/client.js +66 -452
  37. package/examples/controls/12) window, Select_Options control/server.js +19 -117
  38. package/examples/controls/13) window, Dropdown_Menu control/client.js +66 -0
  39. package/examples/controls/13) window, Dropdown_Menu control/server.js +20 -0
  40. package/examples/controls/2) two windows/client.js +193 -193
  41. package/examples/controls/2) two windows/server.js +113 -113
  42. package/examples/controls/3) five windows/client.js +217 -217
  43. package/examples/controls/3) five windows/server.js +116 -115
  44. package/examples/controls/4) window, tabbed panel/client.js +54 -225
  45. package/examples/controls/4) window, tabbed panel/server.js +17 -117
  46. package/examples/controls/5) window, grid/client.js +204 -484
  47. package/examples/controls/5) window, grid/server.js +117 -119
  48. package/examples/controls/6) window, color_palette/client.js +68 -204
  49. package/examples/controls/6) window, color_palette/server.js +117 -117
  50. package/examples/controls/7) window, month_view/client.js +40 -231
  51. package/examples/controls/7) window, month_view/server.js +117 -117
  52. package/examples/controls/8) window, checkbox/client.js +33 -209
  53. package/examples/controls/8) window, checkbox/server.js +117 -117
  54. package/examples/controls/9) window, date picker/client.js +76 -303
  55. package/examples/controls/9) window, date picker/server.js +117 -117
  56. package/examples/controls/9b) window, shared data.model mirrored date pickers/README.md +51 -0
  57. package/examples/controls/9b) window, shared data.model mirrored date pickers/client.js +83 -398
  58. package/examples/controls/9b) window, shared data.model mirrored date pickers/server.js +117 -117
  59. package/examples/controls/__old/_html-server-color-palette.js +114 -114
  60. package/examples/controls/__old/html-server-combo-box.js +104 -104
  61. package/examples/controls/__old/html-server-list.js +98 -98
  62. package/examples/controls/__old/html-server-popup-menu-button.js +114 -114
  63. package/examples/controls/__old/html-server-start-stop-toggle-button.js +146 -146
  64. package/examples/controls/__old/scs-arrow-button.js +36 -36
  65. package/examples/controls/__old/scs-date-picker.js +157 -157
  66. package/examples/controls/__old/scs-file-browser.js +82 -82
  67. package/examples/controls/__old/scs-item.js +159 -159
  68. package/examples/controls/__old/scs-month-arrow-selector.js +126 -126
  69. package/examples/controls/__old/scs-month-view.js +94 -94
  70. package/examples/controls/__old/scs-start-stop-toggle-button.js +40 -40
  71. package/examples/controls/__old/scs-tree.js +49 -49
  72. package/examples/controls/__old/scs-year-arrow-selector.js +127 -127
  73. package/examples/demos/date-picker.js +119 -119
  74. package/examples/demos/explain-encapsulation.js +9 -9
  75. package/examples/demos/resizing.js +35 -35
  76. package/examples/demos/server_time.js +6 -6
  77. package/examples/grids/grid_1.js +45 -45
  78. package/examples/grids/grid_1_client.js +329 -329
  79. package/examples/html-rendering.js +20 -20
  80. package/examples/html-server.js +105 -105
  81. package/examples/introducing jsgui3/server.js +110 -110
  82. package/examples/mx_display/mx_display_1.js +45 -45
  83. package/examples/mx_display/mx_display_1_client.js +444 -444
  84. package/fs2.js +1836 -1836
  85. package/http/responders/HTTP_Responder.js +15 -15
  86. package/http/responders/static/Static_Route_HTTP_Responder.js +105 -105
  87. package/module.js +34 -34
  88. package/old/_single-control-server.js +418 -418
  89. package/old/single-control-server.js +368 -368
  90. package/old/single-page-app.js +131 -131
  91. package/package.json +42 -42
  92. package/page-context.js +92 -92
  93. package/publishers/helpers/assigners/Assigner.js +10 -10
  94. package/publishers/helpers/assigners/static-compressed-response-buffers/Single_Control_Webpage_Server_Static_Compressed_Response_Buffers_Assigner.js +150 -150
  95. package/publishers/helpers/assigners/static-headers/Single_Control_Webpage_Server_Static_Headers_Assigner.js +109 -109
  96. package/publishers/helpers/assigners/static-routes/Single_Control_Webpage_Server_Static_Routes_Assigner.js +91 -91
  97. package/publishers/helpers/assigners/static-uncompressed-response-buffers/Single_Control_Webpage_Server_Static_Uncompressed_Response_Buffers_Assigner.js +104 -104
  98. package/publishers/helpers/preparers/static/bundle/Ready_To_Serve_Preparer.js +18 -18
  99. package/publishers/helpers/preparers/static/bundle/Static_Routes_Responses_Webpage_Bundle_Preparer.js +44 -44
  100. package/publishers/http-function-publisher.js +212 -212
  101. package/publishers/http-html-page-publisher.js +5 -5
  102. package/publishers/http-html-publisher.js +24 -24
  103. package/publishers/http-js-publisher.js +135 -135
  104. package/publishers/http-observable-publisher.js +124 -124
  105. package/publishers/http-publisher.js +53 -53
  106. package/publishers/http-resource-publisher.js +325 -325
  107. package/publishers/http-webpage-publisher.js +659 -658
  108. package/publishers/http-webpageorsite-publisher.js +343 -343
  109. package/publishers/http-website-publisher.js +640 -640
  110. package/publishers/notes.md +9 -9
  111. package/resources/README.md +16 -16
  112. package/resources/_old_website-javascript-resource.js +994 -994
  113. package/resources/_old_website-resource.js +507 -507
  114. package/resources/compile/server-resource-compilation.js +43 -43
  115. package/resources/data-resource.js +118 -118
  116. package/resources/fs-resource.js +146 -146
  117. package/resources/jsbuilder/Abstract_Single_Declaration.js +105 -105
  118. package/resources/jsbuilder/Abstract_Single_Declaration_Sequence.js +42 -42
  119. package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node.js +61 -61
  120. package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node_Group.js +41 -41
  121. package/resources/jsbuilder/JS_AST/JS_AST_Group_Shared.js +61 -61
  122. package/resources/jsbuilder/JS_AST/JS_AST_Node.js +93 -93
  123. package/resources/jsbuilder/JS_AST/JS_AST_Node_0-Core.js +253 -253
  124. package/resources/jsbuilder/JS_AST/JS_AST_Node_1-Babel.js +337 -337
  125. package/resources/jsbuilder/JS_AST/JS_AST_Node_10-Changing.js +39 -39
  126. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.1-Child.js +96 -96
  127. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.2-Parent.js +37 -37
  128. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.3-Ancestor.js +61 -61
  129. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.2-Inner.js +43 -43
  130. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.3-All.js +72 -72
  131. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.4-Sibling.js +92 -92
  132. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.5-Available_In_Scope.js +29 -29
  133. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.9-Signature.js +116 -116
  134. package/resources/jsbuilder/JS_AST/JS_AST_Node_3-Basics.js +159 -159
  135. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.0-Basics_First.js +178 -178
  136. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.1-Basics_Second.js +87 -87
  137. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.99-Basics_Last.js +91 -91
  138. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1-Basics_Each.js +136 -136
  139. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1.5-Basics_Count.js +73 -73
  140. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.2-Basics_Filter.js +39 -39
  141. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.3-Basics_Collect.js +85 -85
  142. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.4-Basics_Select.js +42 -42
  143. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.5-Basics_Find.js +40 -40
  144. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.6-Basics_Callmap.js +54 -54
  145. package/resources/jsbuilder/JS_AST/JS_AST_Node_4.0-Index_Indexes.js +45 -45
  146. package/resources/jsbuilder/JS_AST/JS_AST_Node_4.1-Index.js +343 -343
  147. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.0-Category.js +38 -38
  148. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.1-Category_Identifier.js +30 -30
  149. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.2-Category_Literal.js +28 -28
  150. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.3-Category_Expression.js +26 -26
  151. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.4-Category_Pattern.js +8 -8
  152. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.5-Category_Declaration.js +43 -43
  153. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.6-Category_Statement.js +21 -21
  154. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.0-Type.js +89 -89
  155. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.1-Type_Class_Declaration.js +8 -8
  156. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.2-Type_Variable_Declaration.js +27 -27
  157. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.3-Type_Variable_Declarator.js +28 -28
  158. package/resources/jsbuilder/JS_AST/JS_AST_Node_7-Query.js +736 -736
  159. package/resources/jsbuilder/JS_AST/JS_AST_Node_8-Features.js +64 -64
  160. package/resources/jsbuilder/JS_AST/JS_AST_Node_9-Planning.js +31 -31
  161. package/resources/jsbuilder/JS_AST/JS_AST_Node_Arrangement.js +15 -15
  162. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Declared_Object.js +305 -305
  163. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature.js +77 -77
  164. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declaration.js +248 -248
  165. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declarator.js +138 -138
  166. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature.js +10 -10
  167. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exported.js +100 -100
  168. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exports.js +60 -60
  169. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Interpreted.js +179 -179
  170. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/_JSGUI_Root_Node_Interpreted.js +43 -43
  171. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/special_case_objectassign_to_object.js +12 -12
  172. package/resources/jsbuilder/JS_AST/JS_AST_Node_Group.js +35 -35
  173. package/resources/jsbuilder/JS_AST/JS_AST_Operation.js +11 -11
  174. package/resources/jsbuilder/JS_AST/JS_AST_Operation_On_Relationship.js +31 -31
  175. package/resources/jsbuilder/JS_AST/JS_AST_Ordered_Relationship_Node_To_Group.js +37 -37
  176. package/resources/jsbuilder/JS_AST/JS_AST_Ordinal.js +39 -39
  177. package/resources/jsbuilder/JS_AST/JS_AST_Ordinal_Relationship.js +25 -25
  178. package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_To_Group.js +200 -200
  179. package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_Within_Group_To_Node.js +43 -43
  180. package/resources/jsbuilder/JS_AST/_JS_AST_Node_3.8-Query_Features.js +76 -76
  181. package/resources/jsbuilder/JS_AST/query/enable_array_as_queryable.js +227 -227
  182. package/resources/jsbuilder/JS_AST/query/find_object_keys.js +404 -404
  183. package/resources/jsbuilder/JS_AST/query/node_queries.js +8 -8
  184. package/resources/jsbuilder/JS_AST/query/root_query_identidy.js +11 -11
  185. package/resources/jsbuilder/JS_AST_Node_Extended/JSGUI_Singular_Declaration.js +85 -85
  186. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Declaration.js +123 -123
  187. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended.js +87 -87
  188. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended_0-Core.js +10 -10
  189. package/resources/jsbuilder/JS_Builder.js +10 -10
  190. package/resources/jsbuilder/JS_File/Feature/JS_File_Declared_Object.js +31 -31
  191. package/resources/jsbuilder/JS_File/Feature/JS_File_Exported_Object_Info.js +25 -25
  192. package/resources/jsbuilder/JS_File/Feature/JS_File_Exports.js +78 -78
  193. package/resources/jsbuilder/JS_File/Feature/JS_File_Feature.js +17 -17
  194. package/resources/jsbuilder/JS_File/Feature/JS_File_Imported_Object_Info.js +25 -25
  195. package/resources/jsbuilder/JS_File/Feature/JS_File_Imports.js +8 -8
  196. package/resources/jsbuilder/JS_File/JS_File.js +12 -12
  197. package/resources/jsbuilder/JS_File/JS_File_0-Core.js +202 -202
  198. package/resources/jsbuilder/JS_File/JS_File_1-Early_Parse.js +175 -175
  199. package/resources/jsbuilder/JS_File/JS_File_2-Babel.js +81 -81
  200. package/resources/jsbuilder/JS_File/JS_File_3-JS_AST_Node.js +86 -86
  201. package/resources/jsbuilder/JS_File/JS_File_4-Query.js +413 -413
  202. package/resources/jsbuilder/JS_File/JS_File_4.1-Query_Features.js +414 -414
  203. package/resources/jsbuilder/JS_File/JS_File_5-Planning.js +59 -59
  204. package/resources/jsbuilder/JS_File/JS_File_6-Changing.js +24 -24
  205. package/resources/jsbuilder/JS_File/JS_File_Export_Reference.js +12 -12
  206. package/resources/jsbuilder/JS_File/JS_File_Import_Reference.js +23 -23
  207. package/resources/jsbuilder/JS_File/JS_File_Import_References.js +31 -31
  208. package/resources/jsbuilder/JS_File/JS_File_Processor.js +16 -16
  209. package/resources/jsbuilder/JS_File/JS_Files.js +15 -15
  210. package/resources/jsbuilder/Module.js +14 -14
  211. package/resources/jsbuilder/Platform.js +13 -13
  212. package/resources/jsbuilder/Platforms.js +69 -69
  213. package/resources/jsbuilder/Project.js +109 -109
  214. package/resources/jsbuilder/Reference.js +1 -1
  215. package/resources/jsbuilder/Reference_Sequence.js +16 -16
  216. package/resources/jsbuilder/Scope.js +29 -29
  217. package/resources/jsbuilder/Variable_Name_Provider.js +42 -42
  218. package/resources/jsbuilder/_JS_File.js +225 -225
  219. package/resources/jsbuilder/ast_query.js +20 -20
  220. package/resources/jsbuilder/babel/babel_consts.js +162 -162
  221. package/resources/jsbuilder/babel/babel_node_tools.js +541 -541
  222. package/resources/jsbuilder/babel/deep_iterate/deep_iterate_babel.js +923 -904
  223. package/resources/jsbuilder/build.js +16 -16
  224. package/resources/jsbuilder/platform_notes.md +66 -66
  225. package/resources/jsbuilder/test/test_ast_node.js +381 -381
  226. package/resources/jsbuilder/test/test_js_file.js +303 -303
  227. package/resources/jsbuilder/test/test_project.js +157 -157
  228. package/resources/local-server-info-resource.js +96 -96
  229. package/resources/notes.txt +10 -10
  230. package/resources/old/website-image-resource.js +1185 -1185
  231. package/resources/process-js.js +498 -498
  232. package/resources/processors/bundlers/bundle.js +29 -29
  233. package/resources/processors/bundlers/bundler.js +23 -23
  234. package/resources/processors/bundlers/css-bundler.js +234 -234
  235. package/resources/processors/bundlers/js/JS_Bundler.js +51 -51
  236. package/resources/processors/bundlers/js/esbuild/Advanced_JS_Bundler_Using_ESBuild.js +388 -391
  237. package/resources/processors/bundlers/js/esbuild/Bundler_Using_ESBuild.js +8 -8
  238. package/resources/processors/bundlers/js/esbuild/Core_JS_Non_Minifying_Bundler_Using_ESBuild.js +188 -188
  239. package/resources/processors/bundlers/js/esbuild/Core_JS_Single_File_Minifying_Bundler_Using_ESBuild.js +191 -192
  240. package/resources/processors/bundlers/js/esbuild/_Old_CSS_Extractor.js +239 -239
  241. package/resources/processors/bundlers/js-bundler.js +263 -263
  242. package/resources/processors/bundlers/test_ast.js +73 -73
  243. package/resources/processors/bundlers/webpage-bundler.js +404 -404
  244. package/resources/processors/bundlers/website-bundler.js +22 -22
  245. package/resources/processors/extractors/Extractor.js +9 -11
  246. package/resources/processors/extractors/js/css_and_js/AST_Node/CSS_And_JS_From_JS_String_Using_AST_Node_Extractor.js +239 -254
  247. package/resources/processors/extractors/js/css_and_js/CSS_And_JS_From_JS_String_Extractor.js +3 -3
  248. package/resources/processors/extractors/string/Pos_Span_String_Extractor.js +93 -93
  249. package/resources/server-installed-tools.js +28 -28
  250. package/resources/server-resource-pool.js +41 -41
  251. package/resources/website-audio-resource.js +735 -735
  252. package/resources/website-css-resource.js +411 -411
  253. package/resources/website-image-resource.js +412 -412
  254. package/resources/website-javascript-resource-processor.js +908 -908
  255. package/resources/website-javascript-resource.js +874 -874
  256. package/resources/website-resource-processor.js +10 -10
  257. package/resources/website-resource.js +164 -164
  258. package/resources/website-static-html-resource.js +199 -199
  259. package/resources/website-template-html-resource.js +231 -231
  260. package/roadmap.md +75 -75
  261. package/server.js +609 -573
  262. package/static-page-context.js +13 -13
  263. package/website/webpage.js +81 -81
  264. package/website/website-group.js +15 -15
  265. package/website/website.js +260 -260
  266. package/examples/controls/11d) window, shared model mirrored integer text fields/both.js +0 -17
  267. package/examples/controls/13) window, shared model mirrored lat_long/client.js +0 -933
  268. package/examples/controls/13) window, shared model mirrored lat_long/server.js +0 -50
  269. package/examples/controls/14) window, control compositional model/client.js +0 -328
  270. package/examples/controls/14) window, control compositional model/server.js +0 -118
  271. package/examples/controls/14a) window, control spec has compositional model/client.js +0 -440
  272. package/examples/controls/14a) window, control spec has compositional model/server.js +0 -118
  273. package/examples/controls/15) window, text field/client.js +0 -256
  274. package/examples/controls/16) Window([Text_Input])/client.js +0 -266
  275. package/examples/controls/16) Window([Text_Input])/server.js +0 -109
  276. package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/client.js +0 -494
  277. package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/isomorphic.js +0 -24
  278. package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/server.js +0 -73
  279. package/examples/controls/2b) two window, context menus/client.js +0 -193
  280. package/examples/controls/2b) two window, context menus/server.js +0 -114
  281. package/examples/controls/4a) window, tabbed panel with various controls inside/client.js +0 -233
  282. 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;