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.
- data/AUTHORAILS_README +20 -0
- data/CHANGELOG +1366 -0
- data/MIT-LICENSE +20 -0
- data/README +182 -0
- data/Rakefile +334 -0
- data/bin/about +3 -0
- data/bin/authorails +19 -0
- data/bin/breakpointer +3 -0
- data/bin/console +3 -0
- data/bin/destroy +3 -0
- data/bin/generate +3 -0
- data/bin/performance/benchmarker +3 -0
- data/bin/performance/profiler +3 -0
- data/bin/plugin +3 -0
- data/bin/process/inspector +3 -0
- data/bin/process/reaper +3 -0
- data/bin/process/spawner +3 -0
- data/bin/runner +3 -0
- data/bin/server +3 -0
- data/builtin/rails_info/rails/info.rb +123 -0
- data/builtin/rails_info/rails/info_controller.rb +9 -0
- data/builtin/rails_info/rails/info_helper.rb +2 -0
- data/builtin/rails_info/rails_info_controller.rb +2 -0
- data/configs/apache.conf +40 -0
- data/configs/databases/frontbase.yml +28 -0
- data/configs/databases/mysql.yml +48 -0
- data/configs/databases/oracle.yml +39 -0
- data/configs/databases/postgresql.yml +44 -0
- data/configs/databases/sqlite2.yml +16 -0
- data/configs/databases/sqlite3.yml +19 -0
- data/configs/empty.log +0 -0
- data/configs/lighttpd.conf +54 -0
- data/configs/routes.rb +23 -0
- data/controllers/accounts_controller.rb +11 -0
- data/controllers/admin_controller.rb +76 -0
- data/controllers/begin_controller.rb +5 -0
- data/controllers/login_controller.rb +101 -0
- data/controllers/permission_controller.rb +91 -0
- data/controllers/roles_controller.rb +58 -0
- data/controllers/tables_controller.rb +714 -0
- data/dispatches/dispatch.fcgi +24 -0
- data/dispatches/dispatch.rb +10 -0
- data/dispatches/gateway.cgi +97 -0
- data/doc/README_FOR_APP +2 -0
- data/environments/boot.rb +45 -0
- data/environments/development.rb +21 -0
- data/environments/environment.rb +63 -0
- data/environments/production.rb +18 -0
- data/environments/test.rb +19 -0
- data/fresh_rakefile +10 -0
- data/helpers/application.rb +607 -0
- data/helpers/application_helper.rb +315 -0
- data/helpers/permission_helper.rb +27 -0
- data/helpers/test_helper.rb +28 -0
- data/html/404.html +30 -0
- data/html/500.html +30 -0
- data/html/favicon.ico +0 -0
- data/html/images/ArrowDn.png +0 -0
- data/html/images/ArrowUp.png +0 -0
- data/html/images/arrow.gif +0 -0
- data/html/images/authorails_logo.gif +0 -0
- data/html/images/delete.png +0 -0
- data/html/images/edit.png +0 -0
- data/html/images/minus.gif +0 -0
- data/html/images/plus.gif +0 -0
- data/html/images/rails.png +0 -0
- data/html/images/show.png +0 -0
- data/html/images/spinner.gif +0 -0
- data/html/index.html +273 -0
- data/html/javascripts/application.js +2 -0
- data/html/javascripts/controls.js +833 -0
- data/html/javascripts/dragdrop.js +942 -0
- data/html/javascripts/effects.js +1088 -0
- data/html/javascripts/live_validation.js +4 -0
- data/html/javascripts/prototype.js +2515 -0
- data/html/robots.txt +1 -0
- data/lib/authorails/version.rb +9 -0
- data/lib/binding_of_caller.rb +85 -0
- data/lib/breakpoint.rb +553 -0
- data/lib/breakpoint_client.rb +196 -0
- data/lib/code_statistics.rb +107 -0
- data/lib/commands.rb +17 -0
- data/lib/commands/about.rb +2 -0
- data/lib/commands/breakpointer.rb +1 -0
- data/lib/commands/console.rb +25 -0
- data/lib/commands/destroy.rb +6 -0
- data/lib/commands/generate.rb +6 -0
- data/lib/commands/ncgi/listener +86 -0
- data/lib/commands/ncgi/tracker +69 -0
- data/lib/commands/performance/benchmarker.rb +24 -0
- data/lib/commands/performance/profiler.rb +50 -0
- data/lib/commands/plugin.rb +918 -0
- data/lib/commands/process/inspector.rb +68 -0
- data/lib/commands/process/reaper.rb +149 -0
- data/lib/commands/process/spawner.rb +209 -0
- data/lib/commands/process/spinner.rb +57 -0
- data/lib/commands/runner.rb +48 -0
- data/lib/commands/server.rb +39 -0
- data/lib/commands/servers/base.rb +19 -0
- data/lib/commands/servers/lighttpd.rb +94 -0
- data/lib/commands/servers/mongrel.rb +65 -0
- data/lib/commands/servers/webrick.rb +59 -0
- data/lib/commands/update.rb +4 -0
- data/lib/console_app.rb +27 -0
- data/lib/console_sandbox.rb +6 -0
- data/lib/console_with_helpers.rb +23 -0
- data/lib/dispatcher.rb +173 -0
- data/lib/fcgi_handler.rb +225 -0
- data/lib/initializer.rb +702 -0
- data/lib/rails_generator.rb +43 -0
- data/lib/rails_generator/base.rb +261 -0
- data/lib/rails_generator/commands.rb +581 -0
- data/lib/rails_generator/generated_attribute.rb +42 -0
- data/lib/rails_generator/generators/applications/app/USAGE +16 -0
- data/lib/rails_generator/generators/applications/app/app_generator.rb +341 -0
- data/lib/rails_generator/generators/components/controller/USAGE +30 -0
- data/lib/rails_generator/generators/components/controller/controller_generator.rb +37 -0
- data/lib/rails_generator/generators/components/controller/templates/controller.rb +10 -0
- data/lib/rails_generator/generators/components/controller/templates/functional_test.rb +18 -0
- data/lib/rails_generator/generators/components/controller/templates/helper.rb +2 -0
- data/lib/rails_generator/generators/components/controller/templates/view.rhtml +2 -0
- data/lib/rails_generator/generators/components/integration_test/USAGE +14 -0
- data/lib/rails_generator/generators/components/integration_test/integration_test_generator.rb +16 -0
- data/lib/rails_generator/generators/components/integration_test/templates/integration_test.rb +10 -0
- data/lib/rails_generator/generators/components/mailer/USAGE +18 -0
- data/lib/rails_generator/generators/components/mailer/mailer_generator.rb +34 -0
- data/lib/rails_generator/generators/components/mailer/templates/fixture.rhtml +3 -0
- data/lib/rails_generator/generators/components/mailer/templates/mailer.rb +13 -0
- data/lib/rails_generator/generators/components/mailer/templates/unit_test.rb +37 -0
- data/lib/rails_generator/generators/components/mailer/templates/view.rhtml +3 -0
- data/lib/rails_generator/generators/components/migration/USAGE +14 -0
- data/lib/rails_generator/generators/components/migration/migration_generator.rb +7 -0
- data/lib/rails_generator/generators/components/migration/templates/migration.rb +7 -0
- data/lib/rails_generator/generators/components/model/USAGE +26 -0
- data/lib/rails_generator/generators/components/model/model_generator.rb +38 -0
- data/lib/rails_generator/generators/components/model/templates/fixtures.yml +11 -0
- data/lib/rails_generator/generators/components/model/templates/migration.rb +13 -0
- data/lib/rails_generator/generators/components/model/templates/model.rb +2 -0
- data/lib/rails_generator/generators/components/model/templates/unit_test.rb +10 -0
- data/lib/rails_generator/generators/components/observer/USAGE +15 -0
- data/lib/rails_generator/generators/components/observer/observer_generator.rb +16 -0
- data/lib/rails_generator/generators/components/observer/templates/observer.rb +2 -0
- data/lib/rails_generator/generators/components/observer/templates/unit_test.rb +10 -0
- data/lib/rails_generator/generators/components/plugin/USAGE +35 -0
- data/lib/rails_generator/generators/components/plugin/plugin_generator.rb +38 -0
- data/lib/rails_generator/generators/components/plugin/templates/README +4 -0
- data/lib/rails_generator/generators/components/plugin/templates/Rakefile +22 -0
- data/lib/rails_generator/generators/components/plugin/templates/USAGE +8 -0
- data/lib/rails_generator/generators/components/plugin/templates/generator.rb +8 -0
- data/lib/rails_generator/generators/components/plugin/templates/init.rb +1 -0
- data/lib/rails_generator/generators/components/plugin/templates/install.rb +1 -0
- data/lib/rails_generator/generators/components/plugin/templates/plugin.rb +1 -0
- data/lib/rails_generator/generators/components/plugin/templates/tasks.rake +4 -0
- data/lib/rails_generator/generators/components/plugin/templates/uninstall.rb +1 -0
- data/lib/rails_generator/generators/components/plugin/templates/unit_test.rb +8 -0
- data/lib/rails_generator/generators/components/resource/resource_generator.rb +76 -0
- data/lib/rails_generator/generators/components/resource/templates/USAGE +18 -0
- data/lib/rails_generator/generators/components/resource/templates/controller.rb +2 -0
- data/lib/rails_generator/generators/components/resource/templates/fixtures.yml +11 -0
- data/lib/rails_generator/generators/components/resource/templates/functional_test.rb +20 -0
- data/lib/rails_generator/generators/components/resource/templates/helper.rb +2 -0
- data/lib/rails_generator/generators/components/resource/templates/migration.rb +13 -0
- data/lib/rails_generator/generators/components/resource/templates/model.rb +2 -0
- data/lib/rails_generator/generators/components/resource/templates/unit_test.rb +10 -0
- data/lib/rails_generator/generators/components/scaffold/USAGE +32 -0
- data/lib/rails_generator/generators/components/scaffold/scaffold_generator.rb +208 -0
- data/lib/rails_generator/generators/components/scaffold/templates/controller.rb +134 -0
- data/lib/rails_generator/generators/components/scaffold/templates/form.rhtml +3 -0
- data/lib/rails_generator/generators/components/scaffold/templates/form_scaffolding.rhtml +35 -0
- data/lib/rails_generator/generators/components/scaffold/templates/functional_test.rb +102 -0
- data/lib/rails_generator/generators/components/scaffold/templates/helper.rb +2 -0
- data/lib/rails_generator/generators/components/scaffold/templates/layout.rhtml +17 -0
- data/lib/rails_generator/generators/components/scaffold/templates/partial_list_elements.rhtml +127 -0
- data/lib/rails_generator/generators/components/scaffold/templates/style.css +74 -0
- data/lib/rails_generator/generators/components/scaffold/templates/view_edit.rhtml +75 -0
- data/lib/rails_generator/generators/components/scaffold/templates/view_list.rhtml +30 -0
- data/lib/rails_generator/generators/components/scaffold/templates/view_new.rhtml +8 -0
- data/lib/rails_generator/generators/components/scaffold/templates/view_show.rhtml +37 -0
- data/lib/rails_generator/generators/components/scaffold_resource/USAGE +29 -0
- data/lib/rails_generator/generators/components/scaffold_resource/scaffold_resource_generator.rb +92 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/controller.rb +79 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/fixtures.yml +11 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/functional_test.rb +57 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/helper.rb +2 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/layout.rhtml +17 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/migration.rb +13 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/model.rb +2 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/style.css +74 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/unit_test.rb +10 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/view_edit.rhtml +19 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/view_index.rhtml +24 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/view_new.rhtml +18 -0
- data/lib/rails_generator/generators/components/scaffold_resource/templates/view_show.rhtml +10 -0
- data/lib/rails_generator/generators/components/session_migration/USAGE +15 -0
- data/lib/rails_generator/generators/components/session_migration/session_migration_generator.rb +18 -0
- data/lib/rails_generator/generators/components/session_migration/templates/migration.rb +16 -0
- data/lib/rails_generator/generators/components/web_service/USAGE +28 -0
- data/lib/rails_generator/generators/components/web_service/templates/api_definition.rb +5 -0
- data/lib/rails_generator/generators/components/web_service/templates/controller.rb +8 -0
- data/lib/rails_generator/generators/components/web_service/templates/functional_test.rb +19 -0
- data/lib/rails_generator/generators/components/web_service/web_service_generator.rb +29 -0
- data/lib/rails_generator/lookup.rb +209 -0
- data/lib/rails_generator/manifest.rb +53 -0
- data/lib/rails_generator/options.rb +143 -0
- data/lib/rails_generator/scripts.rb +83 -0
- data/lib/rails_generator/scripts/destroy.rb +7 -0
- data/lib/rails_generator/scripts/generate.rb +7 -0
- data/lib/rails_generator/scripts/update.rb +12 -0
- data/lib/rails_generator/simple_logger.rb +46 -0
- data/lib/rails_generator/spec.rb +44 -0
- data/lib/railties_path.rb +1 -0
- data/lib/ruby_version_check.rb +17 -0
- data/lib/rubyprof_ext.rb +35 -0
- data/lib/tasks/databases.rake +187 -0
- data/lib/tasks/documentation.rake +82 -0
- data/lib/tasks/framework.rake +112 -0
- data/lib/tasks/log.rake +9 -0
- data/lib/tasks/misc.rake +4 -0
- data/lib/tasks/pre_namespace_aliases.rake +53 -0
- data/lib/tasks/rails.rb +8 -0
- data/lib/tasks/statistics.rake +18 -0
- data/lib/tasks/testing.rake +120 -0
- data/lib/tasks/tmp.rake +37 -0
- data/lib/test_help.rb +19 -0
- data/lib/webrick_server.rb +166 -0
- data/libs/migration_helper.rb +11 -0
- data/migrations/001_create_logins.rb +22 -0
- data/migrations/002_create_admins.rb +16 -0
- data/migrations/003_create_roles.rb +13 -0
- data/migrations/004_create_tables.rb +11 -0
- data/migrations/005_create_attr_types.rb +13 -0
- data/migrations/006_create_table_fields.rb +22 -0
- data/migrations/007_create_tab_operations.rb +13 -0
- data/migrations/008_create_attr_operations.rb +13 -0
- data/migrations/009_create_tab_permissions.rb +21 -0
- data/migrations/010_create_attr_permissions.rb +21 -0
- data/migrations/011_create_relations.rb +23 -0
- data/migrations/012_create_scaffolds.rb +11 -0
- data/migrations/013_create_relation_permissions.rb +20 -0
- data/models/admin.rb +38 -0
- data/models/attr_operation.rb +3 -0
- data/models/attr_permission.rb +5 -0
- data/models/attr_type.rb +3 -0
- data/models/login.rb +51 -0
- data/models/relation.rb +5 -0
- data/models/relation_permission.rb +4 -0
- data/models/role.rb +13 -0
- data/models/scaffold.rb +2 -0
- data/models/tab_operation.rb +3 -0
- data/models/tab_permission.rb +5 -0
- data/models/table.rb +18 -0
- data/models/table_field.rb +6 -0
- data/plugins/redhillonrails_core/CHANGELOG +186 -0
- data/plugins/redhillonrails_core/MIT-LICENSE +20 -0
- data/plugins/redhillonrails_core/README +152 -0
- data/plugins/redhillonrails_core/init.rb +1 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/base.rb +54 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/abstract_adapter.rb +46 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/column.rb +21 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/foreign_key_definition.rb +26 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/index_definition.rb +11 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/mysql_adapter.rb +94 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/mysql_column.rb +8 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/postgresql_adapter.rb +131 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/schema_statements.rb +23 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/sqlite3_adapter.rb +9 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/connection_adapters/table_definition.rb +27 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/schema.rb +25 -0
- data/plugins/redhillonrails_core/lib/red_hill_consulting/core/active_record/schema_dumper.rb +58 -0
- data/plugins/redhillonrails_core/lib/redhillonrails_core.rb +19 -0
- data/plugins/redhillonrails_core/tasks/db/comments.rake +9 -0
- data/plugins/schema_validations/CHANGELOG +149 -0
- data/plugins/schema_validations/MIT-LICENSE +20 -0
- data/plugins/schema_validations/README +54 -0
- data/plugins/schema_validations/about.yml +5 -0
- data/plugins/schema_validations/init.rb +1 -0
- data/plugins/schema_validations/install.rb +1 -0
- data/plugins/schema_validations/lib/red_hill_consulting/schema_validations/active_record/base.rb +108 -0
- data/plugins/schema_validations/lib/schema_validations.rb +1 -0
- data/plugins/svn/README +69 -0
- data/plugins/svn/Rakefile +22 -0
- data/plugins/svn/assets/javascripts/live_validation.js +4 -0
- data/plugins/svn/assets/stylesheets/live_validation.css +28 -0
- data/plugins/svn/init.rb +2 -0
- data/plugins/svn/install.rb +1 -0
- data/plugins/svn/lib/form_helpers.rb +49 -0
- data/plugins/svn/lib/live_validations.rb +73 -0
- data/plugins/svn/tasks/live_validation_tasks.rake +17 -0
- data/plugins/svn/test/form_helpers_test.rb +214 -0
- data/plugins/svn/test/live_validations_test.rb +124 -0
- data/plugins/svn/test/resource.rb +17 -0
- data/plugins/svn/uninstall.rb +1 -0
- data/stylesheets/live_validation.css +28 -0
- data/stylesheets/print.css +72 -0
- data/stylesheets/scaffold.css +175 -0
- data/views/accounts/index.rhtml +12 -0
- data/views/accounts/show.rhtml +5 -0
- data/views/admin/_form.rhtml +15 -0
- data/views/admin/add_user.rhtml +21 -0
- data/views/admin/change_pwd.rhtml +23 -0
- data/views/admin/edit_user.rhtml +12 -0
- data/views/admin/index.rhtml +19 -0
- data/views/begin/index.rhtml +0 -0
- data/views/layouts/general.rhtml +59 -0
- data/views/layouts/login.rhtml +18 -0
- data/views/login/change_pwd.rhtml +21 -0
- data/views/login/expired_pwd.rhtml +19 -0
- data/views/login/index.rhtml +15 -0
- data/views/permission/index.rhtml +17 -0
- data/views/permission/relations.rhtml +28 -0
- data/views/permission/roles.rhtml +45 -0
- data/views/permission/tables.rhtml +53 -0
- data/views/roles/_form.rhtml +8 -0
- data/views/roles/edit.rhtml +11 -0
- data/views/roles/list.rhtml +28 -0
- data/views/roles/new.rhtml +8 -0
- data/views/roles/show.rhtml +14 -0
- data/views/shared_views/_advanced_search.rhtml +35 -0
- data/views/shared_views/_child_elements.rhtml +30 -0
- data/views/shared_views/_childs.rhtml +20 -0
- data/views/shared_views/_father_elements.rhtml +27 -0
- data/views/shared_views/_fathers.rhtml +21 -0
- data/views/shared_views/_fathers_header.rhtml +58 -0
- data/views/shared_views/_many_to_many_elements.rhtml +50 -0
- data/views/shared_views/_many_to_manys.rhtml +18 -0
- data/views/shared_views/_one_to_one_elements.rhtml +24 -0
- data/views/shared_views/_one_to_one_father_elements.rhtml +26 -0
- data/views/shared_views/_one_to_ones.rhtml +42 -0
- data/views/shared_views/_one_to_ones_header.rhtml +117 -0
- data/views/shared_views/edit_child.rhtml +89 -0
- data/views/shared_views/edit_many.rhtml +75 -0
- data/views/tables/_cascade.rhtml +10 -0
- data/views/tables/_field.rhtml +10 -0
- data/views/tables/_fk.rhtml +9 -0
- data/views/tables/_form.rhtml +9 -0
- data/views/tables/_join_table_name.rhtml +16 -0
- data/views/tables/_relation_types.rhtml +5 -0
- data/views/tables/_tables.rhtml +15 -0
- data/views/tables/attributes.rhtml +15 -0
- data/views/tables/edit.rhtml +11 -0
- data/views/tables/edit_field.rhtml +18 -0
- data/views/tables/list.rhtml +39 -0
- data/views/tables/new.rhtml +8 -0
- data/views/tables/new_field.rhtml +25 -0
- data/views/tables/relations.rhtml +24 -0
- data/views/tables/show.rhtml +24 -0
- 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
|
data/html/404.html
ADDED
|
@@ -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>
|
data/html/500.html
ADDED
|
@@ -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>
|
data/html/favicon.ico
ADDED
|
File without changes
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|