authorails 1.0.0

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 (347) hide show
  1. data/AUTHORAILS_README +20 -0
  2. data/CHANGELOG +1366 -0
  3. data/MIT-LICENSE +20 -0
  4. data/README +182 -0
  5. data/Rakefile +334 -0
  6. data/bin/about +3 -0
  7. data/bin/authorails +19 -0
  8. data/bin/breakpointer +3 -0
  9. data/bin/console +3 -0
  10. data/bin/destroy +3 -0
  11. data/bin/generate +3 -0
  12. data/bin/performance/benchmarker +3 -0
  13. data/bin/performance/profiler +3 -0
  14. data/bin/plugin +3 -0
  15. data/bin/process/inspector +3 -0
  16. data/bin/process/reaper +3 -0
  17. data/bin/process/spawner +3 -0
  18. data/bin/runner +3 -0
  19. data/bin/server +3 -0
  20. data/builtin/rails_info/rails/info.rb +123 -0
  21. data/builtin/rails_info/rails/info_controller.rb +9 -0
  22. data/builtin/rails_info/rails/info_helper.rb +2 -0
  23. data/builtin/rails_info/rails_info_controller.rb +2 -0
  24. data/configs/apache.conf +40 -0
  25. data/configs/databases/frontbase.yml +28 -0
  26. data/configs/databases/mysql.yml +48 -0
  27. data/configs/databases/oracle.yml +39 -0
  28. data/configs/databases/postgresql.yml +44 -0
  29. data/configs/databases/sqlite2.yml +16 -0
  30. data/configs/databases/sqlite3.yml +19 -0
  31. data/configs/empty.log +0 -0
  32. data/configs/lighttpd.conf +54 -0
  33. data/configs/routes.rb +23 -0
  34. data/controllers/accounts_controller.rb +11 -0
  35. data/controllers/admin_controller.rb +76 -0
  36. data/controllers/begin_controller.rb +5 -0
  37. data/controllers/login_controller.rb +101 -0
  38. data/controllers/permission_controller.rb +91 -0
  39. data/controllers/roles_controller.rb +58 -0
  40. data/controllers/tables_controller.rb +714 -0
  41. data/dispatches/dispatch.fcgi +24 -0
  42. data/dispatches/dispatch.rb +10 -0
  43. data/dispatches/gateway.cgi +97 -0
  44. data/doc/README_FOR_APP +2 -0
  45. data/environments/boot.rb +45 -0
  46. data/environments/development.rb +21 -0
  47. data/environments/environment.rb +63 -0
  48. data/environments/production.rb +18 -0
  49. data/environments/test.rb +19 -0
  50. data/fresh_rakefile +10 -0
  51. data/helpers/application.rb +607 -0
  52. data/helpers/application_helper.rb +315 -0
  53. data/helpers/permission_helper.rb +27 -0
  54. data/helpers/test_helper.rb +28 -0
  55. data/html/404.html +30 -0
  56. data/html/500.html +30 -0
  57. data/html/favicon.ico +0 -0
  58. data/html/images/ArrowDn.png +0 -0
  59. data/html/images/ArrowUp.png +0 -0
  60. data/html/images/arrow.gif +0 -0
  61. data/html/images/authorails_logo.gif +0 -0
  62. data/html/images/delete.png +0 -0
  63. data/html/images/edit.png +0 -0
  64. data/html/images/minus.gif +0 -0
  65. data/html/images/plus.gif +0 -0
  66. data/html/images/rails.png +0 -0
  67. data/html/images/show.png +0 -0
  68. data/html/images/spinner.gif +0 -0
  69. data/html/index.html +273 -0
  70. data/html/javascripts/application.js +2 -0
  71. data/html/javascripts/controls.js +833 -0
  72. data/html/javascripts/dragdrop.js +942 -0
  73. data/html/javascripts/effects.js +1088 -0
  74. data/html/javascripts/live_validation.js +4 -0
  75. data/html/javascripts/prototype.js +2515 -0
  76. data/html/robots.txt +1 -0
  77. data/lib/authorails/version.rb +9 -0
  78. data/lib/binding_of_caller.rb +85 -0
  79. data/lib/breakpoint.rb +553 -0
  80. data/lib/breakpoint_client.rb +196 -0
  81. data/lib/code_statistics.rb +107 -0
  82. data/lib/commands.rb +17 -0
  83. data/lib/commands/about.rb +2 -0
  84. data/lib/commands/breakpointer.rb +1 -0
  85. data/lib/commands/console.rb +25 -0
  86. data/lib/commands/destroy.rb +6 -0
  87. data/lib/commands/generate.rb +6 -0
  88. data/lib/commands/ncgi/listener +86 -0
  89. data/lib/commands/ncgi/tracker +69 -0
  90. data/lib/commands/performance/benchmarker.rb +24 -0
  91. data/lib/commands/performance/profiler.rb +50 -0
  92. data/lib/commands/plugin.rb +918 -0
  93. data/lib/commands/process/inspector.rb +68 -0
  94. data/lib/commands/process/reaper.rb +149 -0
  95. data/lib/commands/process/spawner.rb +209 -0
  96. data/lib/commands/process/spinner.rb +57 -0
  97. data/lib/commands/runner.rb +48 -0
  98. data/lib/commands/server.rb +39 -0
  99. data/lib/commands/servers/base.rb +19 -0
  100. data/lib/commands/servers/lighttpd.rb +94 -0
  101. data/lib/commands/servers/mongrel.rb +65 -0
  102. data/lib/commands/servers/webrick.rb +59 -0
  103. data/lib/commands/update.rb +4 -0
  104. data/lib/console_app.rb +27 -0
  105. data/lib/console_sandbox.rb +6 -0
  106. data/lib/console_with_helpers.rb +23 -0
  107. data/lib/dispatcher.rb +173 -0
  108. data/lib/fcgi_handler.rb +225 -0
  109. data/lib/initializer.rb +702 -0
  110. data/lib/rails_generator.rb +43 -0
  111. data/lib/rails_generator/base.rb +261 -0
  112. data/lib/rails_generator/commands.rb +581 -0
  113. data/lib/rails_generator/generated_attribute.rb +42 -0
  114. data/lib/rails_generator/generators/applications/app/USAGE +16 -0
  115. data/lib/rails_generator/generators/applications/app/app_generator.rb +341 -0
  116. data/lib/rails_generator/generators/components/controller/USAGE +30 -0
  117. data/lib/rails_generator/generators/components/controller/controller_generator.rb +37 -0
  118. data/lib/rails_generator/generators/components/controller/templates/controller.rb +10 -0
  119. data/lib/rails_generator/generators/components/controller/templates/functional_test.rb +18 -0
  120. data/lib/rails_generator/generators/components/controller/templates/helper.rb +2 -0
  121. data/lib/rails_generator/generators/components/controller/templates/view.rhtml +2 -0
  122. data/lib/rails_generator/generators/components/integration_test/USAGE +14 -0
  123. data/lib/rails_generator/generators/components/integration_test/integration_test_generator.rb +16 -0
  124. data/lib/rails_generator/generators/components/integration_test/templates/integration_test.rb +10 -0
  125. data/lib/rails_generator/generators/components/mailer/USAGE +18 -0
  126. data/lib/rails_generator/generators/components/mailer/mailer_generator.rb +34 -0
  127. data/lib/rails_generator/generators/components/mailer/templates/fixture.rhtml +3 -0
  128. data/lib/rails_generator/generators/components/mailer/templates/mailer.rb +13 -0
  129. data/lib/rails_generator/generators/components/mailer/templates/unit_test.rb +37 -0
  130. data/lib/rails_generator/generators/components/mailer/templates/view.rhtml +3 -0
  131. data/lib/rails_generator/generators/components/migration/USAGE +14 -0
  132. data/lib/rails_generator/generators/components/migration/migration_generator.rb +7 -0
  133. data/lib/rails_generator/generators/components/migration/templates/migration.rb +7 -0
  134. data/lib/rails_generator/generators/components/model/USAGE +26 -0
  135. data/lib/rails_generator/generators/components/model/model_generator.rb +38 -0
  136. data/lib/rails_generator/generators/components/model/templates/fixtures.yml +11 -0
  137. data/lib/rails_generator/generators/components/model/templates/migration.rb +13 -0
  138. data/lib/rails_generator/generators/components/model/templates/model.rb +2 -0
  139. data/lib/rails_generator/generators/components/model/templates/unit_test.rb +10 -0
  140. data/lib/rails_generator/generators/components/observer/USAGE +15 -0
  141. data/lib/rails_generator/generators/components/observer/observer_generator.rb +16 -0
  142. data/lib/rails_generator/generators/components/observer/templates/observer.rb +2 -0
  143. data/lib/rails_generator/generators/components/observer/templates/unit_test.rb +10 -0
  144. data/lib/rails_generator/generators/components/plugin/USAGE +35 -0
  145. data/lib/rails_generator/generators/components/plugin/plugin_generator.rb +38 -0
  146. data/lib/rails_generator/generators/components/plugin/templates/README +4 -0
  147. data/lib/rails_generator/generators/components/plugin/templates/Rakefile +22 -0
  148. data/lib/rails_generator/generators/components/plugin/templates/USAGE +8 -0
  149. data/lib/rails_generator/generators/components/plugin/templates/generator.rb +8 -0
  150. data/lib/rails_generator/generators/components/plugin/templates/init.rb +1 -0
  151. data/lib/rails_generator/generators/components/plugin/templates/install.rb +1 -0
  152. data/lib/rails_generator/generators/components/plugin/templates/plugin.rb +1 -0
  153. data/lib/rails_generator/generators/components/plugin/templates/tasks.rake +4 -0
  154. data/lib/rails_generator/generators/components/plugin/templates/uninstall.rb +1 -0
  155. data/lib/rails_generator/generators/components/plugin/templates/unit_test.rb +8 -0
  156. data/lib/rails_generator/generators/components/resource/resource_generator.rb +76 -0
  157. data/lib/rails_generator/generators/components/resource/templates/USAGE +18 -0
  158. data/lib/rails_generator/generators/components/resource/templates/controller.rb +2 -0
  159. data/lib/rails_generator/generators/components/resource/templates/fixtures.yml +11 -0
  160. data/lib/rails_generator/generators/components/resource/templates/functional_test.rb +20 -0
  161. data/lib/rails_generator/generators/components/resource/templates/helper.rb +2 -0
  162. data/lib/rails_generator/generators/components/resource/templates/migration.rb +13 -0
  163. data/lib/rails_generator/generators/components/resource/templates/model.rb +2 -0
  164. data/lib/rails_generator/generators/components/resource/templates/unit_test.rb +10 -0
  165. data/lib/rails_generator/generators/components/scaffold/USAGE +32 -0
  166. data/lib/rails_generator/generators/components/scaffold/scaffold_generator.rb +208 -0
  167. data/lib/rails_generator/generators/components/scaffold/templates/controller.rb +134 -0
  168. data/lib/rails_generator/generators/components/scaffold/templates/form.rhtml +3 -0
  169. data/lib/rails_generator/generators/components/scaffold/templates/form_scaffolding.rhtml +35 -0
  170. data/lib/rails_generator/generators/components/scaffold/templates/functional_test.rb +102 -0
  171. data/lib/rails_generator/generators/components/scaffold/templates/helper.rb +2 -0
  172. data/lib/rails_generator/generators/components/scaffold/templates/layout.rhtml +17 -0
  173. data/lib/rails_generator/generators/components/scaffold/templates/partial_list_elements.rhtml +127 -0
  174. data/lib/rails_generator/generators/components/scaffold/templates/style.css +74 -0
  175. data/lib/rails_generator/generators/components/scaffold/templates/view_edit.rhtml +75 -0
  176. data/lib/rails_generator/generators/components/scaffold/templates/view_list.rhtml +30 -0
  177. data/lib/rails_generator/generators/components/scaffold/templates/view_new.rhtml +8 -0
  178. data/lib/rails_generator/generators/components/scaffold/templates/view_show.rhtml +37 -0
  179. data/lib/rails_generator/generators/components/scaffold_resource/USAGE +29 -0
  180. data/lib/rails_generator/generators/components/scaffold_resource/scaffold_resource_generator.rb +92 -0
  181. data/lib/rails_generator/generators/components/scaffold_resource/templates/controller.rb +79 -0
  182. data/lib/rails_generator/generators/components/scaffold_resource/templates/fixtures.yml +11 -0
  183. data/lib/rails_generator/generators/components/scaffold_resource/templates/functional_test.rb +57 -0
  184. data/lib/rails_generator/generators/components/scaffold_resource/templates/helper.rb +2 -0
  185. data/lib/rails_generator/generators/components/scaffold_resource/templates/layout.rhtml +17 -0
  186. data/lib/rails_generator/generators/components/scaffold_resource/templates/migration.rb +13 -0
  187. data/lib/rails_generator/generators/components/scaffold_resource/templates/model.rb +2 -0
  188. data/lib/rails_generator/generators/components/scaffold_resource/templates/style.css +74 -0
  189. data/lib/rails_generator/generators/components/scaffold_resource/templates/unit_test.rb +10 -0
  190. data/lib/rails_generator/generators/components/scaffold_resource/templates/view_edit.rhtml +19 -0
  191. data/lib/rails_generator/generators/components/scaffold_resource/templates/view_index.rhtml +24 -0
  192. data/lib/rails_generator/generators/components/scaffold_resource/templates/view_new.rhtml +18 -0
  193. data/lib/rails_generator/generators/components/scaffold_resource/templates/view_show.rhtml +10 -0
  194. data/lib/rails_generator/generators/components/session_migration/USAGE +15 -0
  195. data/lib/rails_generator/generators/components/session_migration/session_migration_generator.rb +18 -0
  196. data/lib/rails_generator/generators/components/session_migration/templates/migration.rb +16 -0
  197. data/lib/rails_generator/generators/components/web_service/USAGE +28 -0
  198. data/lib/rails_generator/generators/components/web_service/templates/api_definition.rb +5 -0
  199. data/lib/rails_generator/generators/components/web_service/templates/controller.rb +8 -0
  200. data/lib/rails_generator/generators/components/web_service/templates/functional_test.rb +19 -0
  201. data/lib/rails_generator/generators/components/web_service/web_service_generator.rb +29 -0
  202. data/lib/rails_generator/lookup.rb +209 -0
  203. data/lib/rails_generator/manifest.rb +53 -0
  204. data/lib/rails_generator/options.rb +143 -0
  205. data/lib/rails_generator/scripts.rb +83 -0
  206. data/lib/rails_generator/scripts/destroy.rb +7 -0
  207. data/lib/rails_generator/scripts/generate.rb +7 -0
  208. data/lib/rails_generator/scripts/update.rb +12 -0
  209. data/lib/rails_generator/simple_logger.rb +46 -0
  210. data/lib/rails_generator/spec.rb +44 -0
  211. data/lib/railties_path.rb +1 -0
  212. data/lib/ruby_version_check.rb +17 -0
  213. data/lib/rubyprof_ext.rb +35 -0
  214. data/lib/tasks/databases.rake +187 -0
  215. data/lib/tasks/documentation.rake +82 -0
  216. data/lib/tasks/framework.rake +112 -0
  217. data/lib/tasks/log.rake +9 -0
  218. data/lib/tasks/misc.rake +4 -0
  219. data/lib/tasks/pre_namespace_aliases.rake +53 -0
  220. data/lib/tasks/rails.rb +8 -0
  221. data/lib/tasks/statistics.rake +18 -0
  222. data/lib/tasks/testing.rake +120 -0
  223. data/lib/tasks/tmp.rake +37 -0
  224. data/lib/test_help.rb +19 -0
  225. data/lib/webrick_server.rb +166 -0
  226. data/libs/migration_helper.rb +11 -0
  227. data/migrations/001_create_logins.rb +22 -0
  228. data/migrations/002_create_admins.rb +16 -0
  229. data/migrations/003_create_roles.rb +13 -0
  230. data/migrations/004_create_tables.rb +11 -0
  231. data/migrations/005_create_attr_types.rb +13 -0
  232. data/migrations/006_create_table_fields.rb +22 -0
  233. data/migrations/007_create_tab_operations.rb +13 -0
  234. data/migrations/008_create_attr_operations.rb +13 -0
  235. data/migrations/009_create_tab_permissions.rb +21 -0
  236. data/migrations/010_create_attr_permissions.rb +21 -0
  237. data/migrations/011_create_relations.rb +23 -0
  238. data/migrations/012_create_scaffolds.rb +11 -0
  239. data/migrations/013_create_relation_permissions.rb +20 -0
  240. data/models/admin.rb +38 -0
  241. data/models/attr_operation.rb +3 -0
  242. data/models/attr_permission.rb +5 -0
  243. data/models/attr_type.rb +3 -0
  244. data/models/login.rb +51 -0
  245. data/models/relation.rb +5 -0
  246. data/models/relation_permission.rb +4 -0
  247. data/models/role.rb +13 -0
  248. data/models/scaffold.rb +2 -0
  249. data/models/tab_operation.rb +3 -0
  250. data/models/tab_permission.rb +5 -0
  251. data/models/table.rb +18 -0
  252. data/models/table_field.rb +6 -0
  253. data/plugins/redhillonrails_core/CHANGELOG +186 -0
  254. data/plugins/redhillonrails_core/MIT-LICENSE +20 -0
  255. data/plugins/redhillonrails_core/README +152 -0
  256. data/plugins/redhillonrails_core/init.rb +1 -0
  257. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/base.rb +54 -0
  258. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/abstract_adapter.rb +46 -0
  259. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/column.rb +21 -0
  260. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/foreign_key_definition.rb +26 -0
  261. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/index_definition.rb +11 -0
  262. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/mysql_adapter.rb +94 -0
  263. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/mysql_column.rb +8 -0
  264. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/postgresql_adapter.rb +131 -0
  265. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/schema_statements.rb +23 -0
  266. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/sqlite3_adapter.rb +9 -0
  267. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/table_definition.rb +27 -0
  268. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/schema.rb +25 -0
  269. data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/schema_dumper.rb +58 -0
  270. data/plugins/redhillonrails_core/lib/redhillonrails_core.rb +19 -0
  271. data/plugins/redhillonrails_core/tasks/db/comments.rake +9 -0
  272. data/plugins/schema_validations/CHANGELOG +149 -0
  273. data/plugins/schema_validations/MIT-LICENSE +20 -0
  274. data/plugins/schema_validations/README +54 -0
  275. data/plugins/schema_validations/about.yml +5 -0
  276. data/plugins/schema_validations/init.rb +1 -0
  277. data/plugins/schema_validations/install.rb +1 -0
  278. data/plugins/schema_validations/lib/red_hill_consulting/schema_validations/active_record/base.rb +108 -0
  279. data/plugins/schema_validations/lib/schema_validations.rb +1 -0
  280. data/plugins/svn/README +69 -0
  281. data/plugins/svn/Rakefile +22 -0
  282. data/plugins/svn/assets/javascripts/live_validation.js +4 -0
  283. data/plugins/svn/assets/stylesheets/live_validation.css +28 -0
  284. data/plugins/svn/init.rb +2 -0
  285. data/plugins/svn/install.rb +1 -0
  286. data/plugins/svn/lib/form_helpers.rb +49 -0
  287. data/plugins/svn/lib/live_validations.rb +73 -0
  288. data/plugins/svn/tasks/live_validation_tasks.rake +17 -0
  289. data/plugins/svn/test/form_helpers_test.rb +214 -0
  290. data/plugins/svn/test/live_validations_test.rb +124 -0
  291. data/plugins/svn/test/resource.rb +17 -0
  292. data/plugins/svn/uninstall.rb +1 -0
  293. data/stylesheets/live_validation.css +28 -0
  294. data/stylesheets/print.css +72 -0
  295. data/stylesheets/scaffold.css +175 -0
  296. data/views/accounts/index.rhtml +12 -0
  297. data/views/accounts/show.rhtml +5 -0
  298. data/views/admin/_form.rhtml +15 -0
  299. data/views/admin/add_user.rhtml +21 -0
  300. data/views/admin/change_pwd.rhtml +23 -0
  301. data/views/admin/edit_user.rhtml +12 -0
  302. data/views/admin/index.rhtml +19 -0
  303. data/views/begin/index.rhtml +0 -0
  304. data/views/layouts/general.rhtml +59 -0
  305. data/views/layouts/login.rhtml +18 -0
  306. data/views/login/change_pwd.rhtml +21 -0
  307. data/views/login/expired_pwd.rhtml +19 -0
  308. data/views/login/index.rhtml +15 -0
  309. data/views/permission/index.rhtml +17 -0
  310. data/views/permission/relations.rhtml +28 -0
  311. data/views/permission/roles.rhtml +45 -0
  312. data/views/permission/tables.rhtml +53 -0
  313. data/views/roles/_form.rhtml +8 -0
  314. data/views/roles/edit.rhtml +11 -0
  315. data/views/roles/list.rhtml +28 -0
  316. data/views/roles/new.rhtml +8 -0
  317. data/views/roles/show.rhtml +14 -0
  318. data/views/shared_views/_advanced_search.rhtml +35 -0
  319. data/views/shared_views/_child_elements.rhtml +30 -0
  320. data/views/shared_views/_childs.rhtml +20 -0
  321. data/views/shared_views/_father_elements.rhtml +27 -0
  322. data/views/shared_views/_fathers.rhtml +21 -0
  323. data/views/shared_views/_fathers_header.rhtml +58 -0
  324. data/views/shared_views/_many_to_many_elements.rhtml +50 -0
  325. data/views/shared_views/_many_to_manys.rhtml +18 -0
  326. data/views/shared_views/_one_to_one_elements.rhtml +24 -0
  327. data/views/shared_views/_one_to_one_father_elements.rhtml +26 -0
  328. data/views/shared_views/_one_to_ones.rhtml +42 -0
  329. data/views/shared_views/_one_to_ones_header.rhtml +117 -0
  330. data/views/shared_views/edit_child.rhtml +89 -0
  331. data/views/shared_views/edit_many.rhtml +75 -0
  332. data/views/tables/_cascade.rhtml +10 -0
  333. data/views/tables/_field.rhtml +10 -0
  334. data/views/tables/_fk.rhtml +9 -0
  335. data/views/tables/_form.rhtml +9 -0
  336. data/views/tables/_join_table_name.rhtml +16 -0
  337. data/views/tables/_relation_types.rhtml +5 -0
  338. data/views/tables/_tables.rhtml +15 -0
  339. data/views/tables/attributes.rhtml +15 -0
  340. data/views/tables/edit.rhtml +11 -0
  341. data/views/tables/edit_field.rhtml +18 -0
  342. data/views/tables/list.rhtml +39 -0
  343. data/views/tables/new.rhtml +8 -0
  344. data/views/tables/new_field.rhtml +25 -0
  345. data/views/tables/relations.rhtml +24 -0
  346. data/views/tables/show.rhtml +24 -0
  347. metadata +518 -0
@@ -0,0 +1,315 @@
1
+ # Methods added to this helper will be available to all templates in the application.
2
+ module ApplicationHelper
3
+
4
+ def fathers_for_list(object)
5
+ @code=""
6
+ unless @fathers.nil?
7
+ @fathers.each do |father|
8
+ unless object.send(father).nil? #if the row has an associated father
9
+ for column in father.camelize.constantize.content_columns
10
+ if session[:superuser] #superuser can view anything
11
+ @code << "<td>" + h(object.send(father).send(column.name)) + "</td>"
12
+ else #we have to check if the user can view the field
13
+ @fields_readable[father].each do |field|
14
+ if column.name == field.name
15
+ @code << "<td>" + h(object.send(father).send(column.name)) + "</td>"
16
+ end
17
+ end
18
+ end
19
+ end
20
+ else
21
+ for column in father.camelize.constantize.content_columns
22
+ if session[:superuser] #superuser can view anything
23
+ @code << "<td></td>"
24
+ else #we have to check if the user can view the field
25
+ @fields_readable[father].each do |field|
26
+ if column.name == field.name
27
+ @code << "<td></td>"
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
34
+ end
35
+ return @code
36
+ end
37
+
38
+ def one_to_ones_for_list(object)
39
+ @code=""
40
+ unless @one_to_ones.nil?
41
+ @one_to_ones.each do |one|
42
+ unless object.send(one).nil?
43
+ for column in one.camelize.constantize.content_columns
44
+ if session[:superuser] #superuser can view anything
45
+ @code << "<td>" + h(object.send(one).send(column.name)) + "</td>"
46
+ else #we have to check if the user can view the field
47
+ @fields_readable[one].each do |field|
48
+ if column.name == field.name
49
+ @code << "<td>" + h(object.send(one).send(column.name)) + "</td>"
50
+ end
51
+ end
52
+ end
53
+ end
54
+ else
55
+ for column in one.camelize.constantize.content_columns
56
+ if session[:superuser] #superuser can view anything
57
+ @code << "<td></td>"
58
+ else #we have to check if the user can view the field
59
+ @fields_readable[one].each do |field|
60
+ if column.name == field.name
61
+ @code << "<td></td>"
62
+ end
63
+ end
64
+ end
65
+ end
66
+ end
67
+ end
68
+ end
69
+
70
+ unless @one_to_one_fathers.nil?
71
+ @one_to_one_fathers.each do |one|
72
+ unless object.send(one).nil?
73
+ for column in one.camelize.constantize.content_columns
74
+ if session[:superuser] #superuser can view anything
75
+ @code << "<td>" + h(object.send(one).send(column.name)) + "</td>"
76
+ else #we have to check if the user can view the field
77
+ @fields_readable[one].each do |field|
78
+ if column.name == field.name
79
+ @code << "<td>" + h(object.send(one).send(column.name)) + "</td>"
80
+ end
81
+ end
82
+ end
83
+ end
84
+ else
85
+ for column in one.camelize.constantize.content_columns
86
+ if session[:superuser] #superuser can view anything
87
+ @code << "<td></td>"
88
+ else #we have to check if the user can view the field
89
+ @fields_readable[one].each do |field|
90
+ if column.name == field.name
91
+ @code << "<td></td>"
92
+ end
93
+ end
94
+ end
95
+ end
96
+ end
97
+ end
98
+ end
99
+
100
+ return @code
101
+ end
102
+
103
+ def verse(object)
104
+ if object.relation_type=="many-to-many"
105
+ return "<->"
106
+ else
107
+ return "<-"
108
+ end
109
+ end
110
+
111
+ def check_update(object,attribute,code_if_privileged,code_if_not_privileged)
112
+ if (controller.action_name=="edit" or controller.action_name=="update") and !session[:superuser]
113
+ found=false #variable for checking if the user has the privileges
114
+ @fields_editable.each do |field|
115
+ if attribute == field
116
+ found=true #the user can update the field
117
+ return code_if_privileged
118
+ end
119
+ end
120
+ if !found #the user can't update the field
121
+ found=false
122
+ for field in @fields_readable[:self]
123
+ if attribute == field.name
124
+ found=true #the user can't update the field, but can read it
125
+ return code_if_not_privileged
126
+ end
127
+ end
128
+ if !found #the user can't either edit and read the field
129
+ return "<span id='green'>Not readable</span>"
130
+ end
131
+ end
132
+
133
+ else
134
+ return code_if_privileged
135
+ end
136
+ end
137
+
138
+ def check_if_child(father,child)
139
+ fk_name=controller.controller_name.singularize.foreign_key
140
+ if child.send(fk_name)==father.id
141
+ return "checked"
142
+ else
143
+ return ""
144
+ end
145
+ end
146
+
147
+ def check_if_related(current,related_table,join_table)
148
+ fk_name1=controller.controller_name.singularize.foreign_key #name of the first foreign key
149
+ fk_name2=@table.singularize.foreign_key #name of the second foreign key
150
+ @found=false
151
+ current.send(join_table).each {|row|
152
+ if row.send(fk_name1)==current.id and row.send(fk_name2)==related_table.id
153
+ @found=true
154
+ end
155
+ }
156
+ if @found
157
+ return "checked"
158
+ else
159
+ return ""
160
+ end
161
+ end
162
+
163
+ def pagination_links_remote(paginator,action,update) #for ajax pagination
164
+ page_options = {:window_size => 1}
165
+ pagination_links_each(paginator, page_options) do |n|
166
+ options = {
167
+ :url => {:action => action, :params => @params.merge({:page => n})},
168
+ :update => update,
169
+ :before => "Element.show('spinner')",
170
+ :success => "Element.hide('spinner')"
171
+ }
172
+ html_options = {:href => url_for(:action => action, :params => @params.merge({:page => n}))}
173
+ link_to_remote(n.to_s, options, html_options)
174
+
175
+ end
176
+ end
177
+
178
+ def check_relation_privileges(model_name,foreign_key,referenced_object,referenced_table,object)
179
+ can_create=false
180
+ can_destroy=false
181
+ can_update=false
182
+ can_create=true if session[:superuser] #superuser can do anything
183
+ can_destroy=true if session[:superuser] #superuser can do anything
184
+ can_update=true if session[:superuser] #superuser can do anything
185
+ @relations_to_create.each {|r|
186
+ can_create=true if referenced_table==r
187
+ }
188
+ @relations_to_destroy.each {|r|
189
+ can_destroy=true if referenced_table==r
190
+ }
191
+ @relations_to_update.each {|r|
192
+ can_update=true if referenced_table==r
193
+ }
194
+
195
+ #if user can create and destroy a relation
196
+ if can_create and can_destroy
197
+ if can_update or object.send(referenced_table.singularize).nil? #we add a select with a blank field
198
+ return select( model_name,foreign_key,referenced_object,:include_blank => true)
199
+ else
200
+ return select_tag( model_name + "[" + foreign_key + "]","<option value=''></option><option value='#{object.send(referenced_table.singularize).id}' selected>#{readable_columns(object.send(referenced_table.singularize),referenced_table)}</option>") + " <span id='green'>N.B.:you can only destroy the relation</span>"
201
+ end
202
+ end
203
+ #if user can create but can't destroy a relation, we add a select without a blank field if there is no association between the tables (if the fk of the related table is null)
204
+ if can_create and !can_destroy
205
+ if can_update #we add a select without a blank field
206
+ if object.send(referenced_table.singularize).nil?
207
+ return select( model_name,foreign_key,referenced_object,:include_blank => true)
208
+ else
209
+ return select( model_name,foreign_key,referenced_object,:include_blank => false)
210
+ end
211
+ elsif object.send(referenced_table.singularize).nil?
212
+ return select( model_name,foreign_key,referenced_object,:include_blank => true)
213
+ else
214
+ return "<br />#{readable_columns(object.send(referenced_table.singularize),referenced_table)} <span id='green'>You can't update and neither destroy the relation</span>"
215
+ end
216
+ end
217
+ #if user can't create but can destroy a relation, we add a select with a blank field if there is an association between the tables (if the fk of the related table is not null)
218
+ if !can_create and can_destroy
219
+ if can_update and !object.send(referenced_table.singularize).nil?
220
+ return select( model_name,foreign_key,referenced_object,:include_blank => true)
221
+ elsif !object.send(referenced_table.singularize).nil?
222
+ return select_tag( model_name + "[" + foreign_key + "]","<option value=''></option><option value='#{object.send(referenced_table.singularize).id}' selected>#{readable_columns(object.send(referenced_table.singularize),referenced_table)}</option>") + " <span id='green'>N.B.:you can only destroy the relation</span>"
223
+ else
224
+ return "<span id='green'>You can't create the relation</span>"
225
+ end
226
+ end
227
+ #if user can't create and destroy a relation, we add a select without a blank field if the user can update an existing association
228
+ if !can_create and !can_destroy
229
+ if can_update and !object.send(referenced_table.singularize).nil?
230
+ return select( model_name,foreign_key,referenced_object,:include_blank => false)
231
+ else
232
+ return "<span id='green'>You can't update the relation</span>"
233
+ end
234
+ end
235
+ end
236
+
237
+ def check_relation_privileges2(model_name,foreign_key,referenced_object,selected,object)
238
+ can_create=false
239
+ can_destroy=false
240
+ can_update=false
241
+ can_create=true if session[:superuser] #superuser can do anything
242
+ can_destroy=true if session[:superuser] #superuser can do anything
243
+ can_update=true if session[:superuser] #superuser can do anything
244
+ @relations_to_create.each {|r|
245
+ can_create=true if model_name.pluralize==r
246
+ }
247
+ @relations_to_destroy.each {|r|
248
+ can_destroy=true if model_name.pluralize==r
249
+ }
250
+ @relations_to_update.each {|r|
251
+ can_update=true if model_name.pluralize==r
252
+ }
253
+
254
+ #if user can create and destroy a relation
255
+ if can_create and can_destroy
256
+ if can_update or object.send(model_name).nil? #we add a select with a blank field
257
+ return select( model_name,foreign_key,referenced_object,:selected => selected,:include_blank => true)
258
+ else
259
+ return select_tag( model_name + "[" + foreign_key.to_s + "]","<option value=''></option><option value='#{object.send(model_name).id}' selected>#{readable_columns(object.send(model_name),model_name.pluralize)}</option>") + " <span id='green'>N.B.:you can only destroy the relation</span>"
260
+ end
261
+ end
262
+ #if user can create but can't destroy a relation, we add a select without a blank field if there is no association between the tables (if the fk of the related table is null)
263
+ if can_create and !can_destroy
264
+ if can_update #we add a select without a blank field
265
+ if object.send(model_name).nil?
266
+ return select( model_name,foreign_key,referenced_object,:include_blank => true)
267
+ else
268
+ return select( model_name,foreign_key,referenced_object,:selected => selected,:include_blank => false)
269
+ end
270
+ elsif object.send(model_name).nil?
271
+ return select( model_name,foreign_key,referenced_object,:selected => selected,:include_blank => true)
272
+ else
273
+ return "<br />#{readable_columns(object.send(model_name),model_name.pluralize)} <span id='green'>You can't update and neither destroy the relation</span>"
274
+ end
275
+ end
276
+ #if user can't create but can destroy a relation, we add a select with a blank field if there is an association between the tables (if the fk of the related table is not null)
277
+ if !can_create and can_destroy
278
+ if can_update and !object.send(model_name).nil?
279
+ return select( model_name,foreign_key,referenced_object,:selected => selected,:include_blank => true)
280
+ elsif !object.send(model_name).nil?
281
+ return select_tag( model_name + "[" + foreign_key.to_s + "]","<option value=''></option><option value='#{object.send(model_name).id}' selected>#{readable_columns(object.send(model_name),model_name.pluralize)}</option>") + " <span id='green'>N.B.:you can only destroy the relation</span>"
282
+ else
283
+ return "<span id='green'>You can't create the relation</span>"
284
+ end
285
+ end
286
+ #if user can't create and destroy a relation, we add a select without a blank field if the user can update an existing association
287
+ if !can_create and !can_destroy
288
+ if can_update and !object.send(model_name).nil?
289
+ return select( model_name,foreign_key,referenced_object,:selected => selected,:include_blank => false)
290
+ else
291
+ return "<span id='green'>You can't update the relation</span>" unless object.send(model_name).nil?
292
+ return "<span id='green'>You can't create the relation</span>" if can_update
293
+ end
294
+ end
295
+ end
296
+
297
+ def readable_columns(object,ref_table)
298
+ string=""
299
+ for column in ref_table.singularize.camelize.constantize.content_columns
300
+ if session[:superuser]
301
+ string += "#{object.send(column.name)} "
302
+ else
303
+ unless @fields_readable[ref_table.singularize].empty?
304
+ @fields_readable[ref_table.singularize].each do |field|
305
+ if column.name == field.name
306
+ string += "#{object.send(column.name)} "
307
+ end
308
+ end
309
+ end
310
+ end
311
+ end
312
+ return string
313
+ end
314
+
315
+ end
@@ -0,0 +1,27 @@
1
+ module PermissionHelper
2
+
3
+ def check(role,table,op)
4
+ if TabPermission.find_by_role_id_and_table_id_and_tab_operation_id(role,table,op)
5
+ return "checked"
6
+ else
7
+ return ""
8
+ end
9
+ end
10
+
11
+ def check2(role,table,op)
12
+ if AttrPermission.find_by_role_id_and_table_field_id_and_attr_operation_id(role,table,op)
13
+ return "checked"
14
+ else
15
+ return ""
16
+ end
17
+ end
18
+
19
+ def check_relation(relation,role,action)
20
+ if RelationPermission.find_by_relation_id_and_role_id_and_action(relation,role,action)
21
+ return "checked"
22
+ else
23
+ return ""
24
+ end
25
+ end
26
+
27
+ end
@@ -0,0 +1,28 @@
1
+ ENV["RAILS_ENV"] = "test"
2
+ require File.expand_path(File.dirname(__FILE__) + "/../config/environment")
3
+ require 'test_help'
4
+
5
+ class Test::Unit::TestCase
6
+ # Transactional fixtures accelerate your tests by wrapping each test method
7
+ # in a transaction that's rolled back on completion. This ensures that the
8
+ # test database remains unchanged so your fixtures don't have to be reloaded
9
+ # between every test method. Fewer database queries means faster tests.
10
+ #
11
+ # Read Mike Clark's excellent walkthrough at
12
+ # http://clarkware.com/cgi/blosxom/2005/10/24#Rails10FastTesting
13
+ #
14
+ # Every Active Record database supports transactions except MyISAM tables
15
+ # in MySQL. Turn off transactional fixtures in this case; however, if you
16
+ # don't care one way or the other, switching from MyISAM to InnoDB tables
17
+ # is recommended.
18
+ self.use_transactional_fixtures = true
19
+
20
+ # Instantiated fixtures are slow, but give you @david where otherwise you
21
+ # would need people(:david). If you don't want to migrate your existing
22
+ # test cases which use the @david style and don't mind the speed hit (each
23
+ # instantiated fixtures translates to a database query per test method),
24
+ # then set this back to true.
25
+ self.use_instantiated_fixtures = false
26
+
27
+ # Add more helper methods to be used by all tests here...
28
+ end
@@ -0,0 +1,30 @@
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
2
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3
+
4
+ <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
5
+
6
+ <head>
7
+ <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
8
+ <title>The page you were looking for doesn't exist (404)</title>
9
+ <style type="text/css">
10
+ body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
11
+ div.dialog {
12
+ width: 25em;
13
+ padding: 0 4em;
14
+ margin: 4em auto 0 auto;
15
+ border: 1px solid #ccc;
16
+ border-right-color: #999;
17
+ border-bottom-color: #999;
18
+ }
19
+ h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
20
+ </style>
21
+ </head>
22
+
23
+ <body>
24
+ <!-- This file lives in public/404.html -->
25
+ <div class="dialog">
26
+ <h1>The page you were looking for doesn't exist.</h1>
27
+ <p>You may have mistyped the address or the page may have moved.</p>
28
+ </div>
29
+ </body>
30
+ </html>
@@ -0,0 +1,30 @@
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
2
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3
+
4
+ <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
5
+
6
+ <head>
7
+ <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
8
+ <title>We're sorry, but something went wrong</title>
9
+ <style type="text/css">
10
+ body { background-color: #fff; color: #666; text-align: center; font-family: arial, sans-serif; }
11
+ div.dialog {
12
+ width: 25em;
13
+ padding: 0 4em;
14
+ margin: 4em auto 0 auto;
15
+ border: 1px solid #ccc;
16
+ border-right-color: #999;
17
+ border-bottom-color: #999;
18
+ }
19
+ h1 { font-size: 100%; color: #f00; line-height: 1.5em; }
20
+ </style>
21
+ </head>
22
+
23
+ <body>
24
+ <!-- This file lives in public/500.html -->
25
+ <div class="dialog">
26
+ <h1>We're sorry, but something went wrong.</h1>
27
+ <p>We've been notified about this issue and we'll take a look at it shortly.</p>
28
+ </div>
29
+ </body>
30
+ </html>
File without changes
Binary file
Binary file
Binary file
Binary file
Binary file