zena 1.0.0.beta3 → 1.0.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +29 -0
- data/Rakefile +2 -0
- data/TODO_ZENA_1_0 +13 -23
- data/app/controllers/columns_controller.rb +1 -1
- data/app/controllers/comments_controller.rb +4 -3
- data/app/controllers/documents_controller.rb +8 -11
- data/app/controllers/nodes_controller.rb +39 -21
- data/app/controllers/users_controller.rb +8 -3
- data/app/controllers/versions_controller.rb +2 -2
- data/app/controllers/virtual_classes_controller.rb +17 -11
- data/app/helpers/documents_helper.rb +0 -3
- data/app/helpers/users_helper.rb +17 -0
- data/app/models/cache.rb +36 -31
- data/app/models/column.rb +48 -5
- data/app/models/comment.rb +14 -5
- data/app/models/data_entry.rb +2 -2
- data/app/models/document.rb +23 -33
- data/app/models/idx_nodes_datetime.rb +4 -0
- data/app/models/idx_nodes_float.rb +4 -0
- data/app/models/idx_project.rb +3 -0
- data/app/models/node.rb +372 -308
- data/app/models/page.rb +1 -31
- data/app/models/relation.rb +4 -4
- data/app/models/relation_proxy.rb +128 -17
- data/app/models/role.rb +27 -2
- data/app/models/site.rb +64 -56
- data/app/models/template.rb +11 -12
- data/app/models/text_document.rb +6 -7
- data/app/models/user.rb +95 -46
- data/app/models/version.rb +2 -2
- data/app/models/virtual_class.rb +418 -73
- data/app/views/columns/_form.html.erb +1 -1
- data/app/views/columns/_li.html.erb +1 -1
- data/app/views/comments/_form.rhtml +1 -1
- data/app/views/comments/_li.rhtml +1 -1
- data/app/views/comments/_li_simple.rhtml +1 -1
- data/app/views/groups/_form.rhtml +1 -1
- data/app/views/links/_li.rhtml +1 -1
- data/app/views/nodes/_groups.rhtml +1 -1
- data/app/views/nodes/_import_results.rhtml +1 -1
- data/app/views/nodes/_parent.rhtml +1 -1
- data/app/views/nodes/_results.rhtml +1 -1
- data/app/views/nodes/create.rjs +4 -2
- data/app/views/relations/_li.erb +2 -2
- data/app/views/templates/document_create_tabs/_file.rhtml +1 -1
- data/app/views/templates/document_create_tabs/_template.rhtml +2 -2
- data/app/views/templates/document_create_tabs/_text_document.rhtml +2 -2
- data/app/views/templates/edit_tabs/_help.rhtml +1 -1
- data/app/views/templates/edit_tabs/_title.rhtml +0 -3
- data/app/views/users/_form.rhtml +2 -6
- data/app/views/users/_li.rhtml +1 -3
- data/app/views/users/create.rjs +4 -4
- data/app/views/users/preferences.html.erb +1 -4
- data/app/views/versions/custom_tab.rhtml +5 -0
- data/app/views/virtual_classes/_form.erb +20 -10
- data/app/views/virtual_classes/_li.erb +21 -8
- data/app/views/zafu/default/Node-+search.zafu +1 -1
- data/app/views/zafu/default/Node.zafu +3 -3
- data/bricks/captcha/lib/bricks/captcha.rb +1 -1
- data/bricks/mongrel/zena/deploy.rb +14 -0
- data/bricks/{data2pdf → pdf}/.document +0 -0
- data/bricks/pdf/README +33 -0
- data/bricks/{data2pdf → pdf}/Rakefile +0 -0
- data/bricks/pdf/VERSION +1 -0
- data/bricks/pdf/lib/bricks/pdf.rb +110 -0
- data/bricks/pdf/lib/bricks/pdf/engine/prince.rb +38 -0
- data/bricks/pdf/lib/bricks/pdf/engine/xhtml2pdf.rb +9 -0
- data/bricks/pdf/lib/bricks/pdf/install.rb +121 -0
- data/bricks/pdf/test/engines/test_prince.rb +15 -0
- data/bricks/pdf/test/engines/test_xhtml2pdf.rb +15 -0
- data/bricks/{data2pdf → pdf}/test/fixtures/application.css +0 -0
- data/bricks/{data2pdf → pdf}/test/fixtures/contact.html +0 -0
- data/bricks/{data2pdf → pdf}/test/fixtures/pisa-default.css +0 -0
- data/bricks/{data2pdf → pdf}/test/fixtures/sheet1.css +0 -0
- data/bricks/{data2pdf → pdf}/test/fixtures/sheet2.css +0 -0
- data/bricks/{data2pdf → pdf}/test/fixtures/simple-html.html +0 -0
- data/bricks/{data2pdf → pdf}/test/fixtures/simple-text.txt +0 -0
- data/bricks/{data2pdf → pdf}/test/helper.rb +4 -5
- data/bricks/pdf/test/shoulda_macros/shoulda_pdf.rb +72 -0
- data/bricks/pdf/zena/init.rb +5 -0
- data/bricks/pdf/zena/tasks.rb +17 -0
- data/bricks/sphinx/lib/{use_sphinx.rb → bricks/sphinx.rb} +1 -1
- data/bricks/tags/zena/init.rb +2 -2
- data/bricks/tags/zena/test/zafu/tags.yml +4 -4
- data/bricks/zena/zena/migrate/01_base.rb +482 -0
- data/config/bricks.yml +22 -6
- data/config/gems.yml +8 -6
- data/db/20100628074512_zena0x_to1x.rb +6 -1
- data/db/fix/024_correct_vclass_kpath.rb +11 -0
- data/db/fix/025_move_tag_into_vclass.rb +13 -0
- data/db/{migrate → fix}/026_rename_templates.rb +0 -0
- data/db/{migrate → fix}/045_avoid_star_in_templates.rb +0 -0
- data/db/{migrate → fix}/046_fix_zazen_image_tag.rb +0 -0
- data/db/{migrate → fix}/047_change_default_link_id_to_zero.rb +1 -3
- data/db/{migrate → fix}/049_fix_publish_from_is_null.rb +0 -0
- data/db/{migrate → fix}/20090924141459_zafu_fix_sept09.rb +0 -0
- data/db/{migrate → fix}/20091013100351_rename_publish_group_to_drive_group.rb +1 -3
- data/db/{migrate → fix}/20091124161608_rebuild_fullpath.rb +0 -1
- data/db/{migrate → fix}/20100115134729_rebuild_fullpath_after_fix.rb +0 -0
- data/db/{migrate → fix}/20100526090140_renamed_contact_model_to_base_contact.rb +2 -4
- data/db/{migrate → fix/old_migrations}/001_create_base.rb +0 -1
- data/db/{migrate → fix/old_migrations}/002_add_time_zone_to_users.rb +0 -0
- data/db/{migrate → fix/old_migrations}/003_add_custom_base_flag.rb +0 -0
- data/db/{migrate → fix/old_migrations}/004_rename_template_skin.rb +0 -0
- data/db/{migrate → fix/old_migrations}/005_create_cached_pages.rb +0 -0
- data/db/{migrate → fix/old_migrations}/006_create_sites.rb +0 -0
- data/db/{migrate → fix/old_migrations}/007_replace_id_by_zip.rb +0 -0
- data/db/{migrate → fix/old_migrations}/008_user_status.rb +0 -0
- data/db/{migrate → fix/old_migrations}/009_fulltext.rb +0 -0
- data/db/fix/old_migrations/010_create_template_content.rb +17 -0
- data/db/{migrate → fix/old_migrations}/011_project_to_section.rb +0 -0
- data/db/{migrate → fix/old_migrations}/012_add_project_id.rb +0 -0
- data/db/{migrate → fix/old_migrations}/013_remove_defaults.rb +0 -0
- data/db/{migrate → fix/old_migrations}/014_add_sort_field.rb +0 -0
- data/db/{migrate → fix/old_migrations}/015_add_dyn_attributes.rb +0 -0
- data/db/{migrate → fix/old_migrations}/016_remove_translations.rb +0 -0
- data/db/{migrate → fix/old_migrations}/017_rename_authorize.rb +0 -0
- data/db/{migrate → fix/old_migrations}/018_add_auth_option.rb +0 -0
- data/db/{migrate → fix/old_migrations}/019_remove_user_status.rb +0 -0
- data/db/{migrate → fix/old_migrations}/020_create_participation.rb +0 -0
- data/db/{migrate → fix/old_migrations}/021_create_relations.rb +0 -0
- data/db/{migrate → fix/old_migrations}/022_create_virtual_classes.rb +0 -0
- data/db/{migrate → fix/old_migrations}/023_ip_on_anonymous_comment.rb +0 -0
- data/db/{migrate → fix/old_migrations}/027_add_country_to_contacts.rb +0 -0
- data/db/{migrate → fix/old_migrations}/028_change_size_of_conten_type_field.rb +0 -0
- data/db/{migrate → fix/old_migrations}/029_create_data_entries.rb +0 -0
- data/db/{migrate → fix/old_migrations}/030_redit_auto_publish_site_settings.rb +0 -0
- data/db/{migrate → fix/old_migrations}/031_create_iformats.rb +0 -0
- data/db/{migrate → fix/old_migrations}/032_caches_context_as_hash.rb +0 -0
- data/db/{migrate → fix/old_migrations}/033_documents_kpath_change.rb +0 -0
- data/db/{migrate → fix/old_migrations}/034_change_file_storage.rb +0 -0
- data/db/{migrate → fix/old_migrations}/035_add_status_to_link.rb +0 -0
- data/db/{migrate → fix/old_migrations}/036_add_flag_fields_on_nodes.rb +0 -0
- data/db/{migrate → fix/old_migrations}/037_add_auto_create_discussion_to_v_class.rb +0 -0
- data/db/{migrate → fix/old_migrations}/038_create_site_attributes.rb +0 -0
- data/db/{migrate → fix/old_migrations}/039_default_position.rb +0 -0
- data/db/{migrate → fix/old_migrations}/040_second_value_for_data_entry.rb +0 -0
- data/db/{migrate → fix/old_migrations}/041_add_attributes_to_v_class.rb +0 -0
- data/db/{migrate → fix/old_migrations}/042_fix_position_should_be_float.rb +0 -0
- data/db/{migrate → fix/old_migrations}/043_move_user_lang_into_participation.rb +0 -0
- data/db/{migrate → fix/old_migrations}/044_remove_monolingual_site_option.rb +0 -0
- data/db/{migrate → fix/old_migrations}/048_link_source_target_can_be_null.rb +0 -0
- data/db/{migrate → fix/old_migrations}/050_date_in_links.rb +0 -0
- data/db/{migrate → fix/old_migrations}/051_add_exif_tags_to_images.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20090825201159_insert_zero_link.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20090825201200_merge_bricks_migrations_with_std_migrations.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20090927125912_allow_null_in_text_fields.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20090928133440_no_more_private_nodes.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20090928143754_version_status_change.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20091001084025_change_status_values_for_comments.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20091009084057_add_vhash_in_node.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20091014130833_fix_template_title.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20091014183726_merge_participation_into_users.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20091018200734_add_popup_info_to_image_format.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20091026161708_add_persistence_token.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20091101184952_add_session_table.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20091123175137_add_single_access_token.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100125062254_add_dynamo_to_version.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100201133242_remove_default_status_on_version.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100208194210_create_attachments.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100210112319_change_dynamo_to_property.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100320145726_transform_template_contents_into_index.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100328125634_change_skin_name_to_id.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100417061257_add_properties_to_sites.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100419163149_rename_name_to_node_name.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100422091606_change_v_class_table_into_roles.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100422094048_node_habtm_roles.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100422115935_create_columns.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100513181529_add_site_id_to_columns.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100519091711_add_index_definition_to_columns.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100519091940_create_idx_nodes_string.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100519232432_create_idx_nodes_ml_string.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100525113858_add_porperties_to_users.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100527130937_change_column_index_to_string.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100531135128_add_fulltext_builder_fields.rb +0 -0
- data/db/{migrate → fix/old_migrations}/20100915062903_add_api_group_id_to_site.rb +0 -0
- data/db/fix/old_migrations/20100923154807_remove_base_contact.rb +84 -0
- data/db/fix/old_migrations/20100926192223_remove_su_user.rb +8 -0
- data/db/fix/old_migrations/20100927141658_add_eval_attributes_to_v_class.rb +12 -0
- data/db/fix/old_migrations/20100928185257_add_obvious_idx.rb +52 -0
- data/db/fix/old_migrations/20100929143111_remove_node_name.rb +11 -0
- data/db/fix/old_migrations/20101006090454_store_properties_in_long_text.rb +9 -0
- data/db/fix/old_migrations/20101014185753_remove_user_prototype_id.rb +9 -0
- data/db/fix/old_migrations/20101101084318_create_scope_index.rb +35 -0
- data/db/fix/old_migrations/20101109074232_create_idx_nodes_tables.rb +65 -0
- data/db/fix/old_migrations/20101110184235_add_role_update_to_site.rb +9 -0
- data/db/fix/old_migrations/20101116103920_change_scope_index.rb +31 -0
- data/db/fix/old_migrations/20101123125822_add_integer_idx.rb +17 -0
- data/db/fix/old_migrations/20101130134522_add_index_field.rb +13 -0
- data/db/fix/old_migrations/20101213133816_add_group_to_relation.rb +9 -0
- data/db/init/base/help.fr.zml +1 -1
- data/db/init/base/skins/default.zml +0 -1
- data/db/init/base/skins/default/Node-+search.zafu +1 -1
- data/db/init/base/skins/default/Node-tree.zafu +3 -3
- data/db/init/base/skins/default/Node.zafu +3 -3
- data/lib/bricks/loader.rb +4 -1
- data/lib/bricks/requirements_validation.rb +11 -6
- data/lib/log_recorder/lib/log_recorder.rb +2 -2
- data/lib/tasks/zena.rake +25 -15
- data/lib/zena.rb +42 -9
- data/lib/zena/acts/enrollable.rb +81 -99
- data/lib/zena/acts/secure.rb +27 -23
- data/lib/zena/acts/secure_node.rb +10 -55
- data/lib/zena/acts/serializable.rb +9 -10
- data/lib/zena/app.rb +0 -2
- data/lib/zena/code_syntax.rb +1 -1
- data/lib/zena/controller/test_case.rb +0 -5
- data/lib/zena/core_ext/string.rb +48 -20
- data/lib/zena/db.rb +10 -442
- data/lib/zena/db_helper/abstract_db.rb +184 -0
- data/lib/zena/db_helper/mysql.rb +150 -0
- data/lib/zena/db_helper/postgresql.rb +79 -0
- data/lib/zena/db_helper/sqlite3.rb +135 -0
- data/lib/zena/deploy.rb +4 -1
- data/lib/zena/deploy/httpd.rhtml +3 -3
- data/lib/zena/deploy/vhost.rhtml +1 -1
- data/lib/zena/foxy_parser.rb +37 -18
- data/lib/zena/info.rb +3 -13
- data/lib/zena/migrator.rb +0 -1
- data/lib/zena/parser/zafu_rules.rb +9 -4
- data/lib/zena/parser/zazen_rules.rb +5 -5
- data/lib/zena/parser/zena_rules.rb +1 -1
- data/lib/zena/remote/interface.rb +1 -1
- data/lib/zena/site_worker.rb +3 -3
- data/lib/zena/test_controller.rb +10 -10
- data/lib/zena/use/action.rb +66 -6
- data/lib/zena/use/ajax.rb +39 -13
- data/lib/zena/use/ancestry.rb +210 -0
- data/lib/zena/use/authlogic.rb +30 -1
- data/lib/zena/use/calendar.rb +158 -0
- data/lib/zena/use/conditional.rb +3 -2
- data/lib/zena/use/context.rb +42 -12
- data/lib/zena/use/dates.rb +15 -14
- data/lib/zena/use/display.rb +54 -7
- data/lib/zena/use/error_rendering.rb +1 -0
- data/lib/zena/use/field_index.rb +20 -0
- data/lib/zena/use/fixtures.rb +12 -9
- data/lib/zena/use/forms.rb +230 -106
- data/lib/zena/use/fulltext.rb +28 -14
- data/lib/zena/use/html_tags.rb +1 -24
- data/lib/zena/use/i18n.rb +69 -14
- data/lib/zena/use/kpath.rb +60 -0
- data/lib/zena/use/ml_index.rb +6 -4
- data/lib/zena/use/node_context.rb +63 -0
- data/lib/zena/use/prop_eval.rb +90 -0
- data/lib/zena/use/query_builder.rb +159 -29
- data/lib/zena/use/query_comment.rb +1 -1
- data/lib/zena/use/query_node.rb +147 -56
- data/lib/zena/use/recursion.rb +2 -2
- data/lib/zena/use/relations.rb +31 -19
- data/lib/zena/use/rendering.rb +111 -121
- data/lib/zena/use/scope_index.rb +230 -0
- data/lib/zena/use/search.rb +7 -7
- data/lib/zena/use/urls.rb +87 -25
- data/lib/zena/use/version_hash.rb +113 -113
- data/lib/zena/use/workflow.rb +5 -1
- data/lib/zena/use/zafu_attributes.rb +11 -14
- data/lib/zena/use/zafu_eval.rb +1 -1
- data/lib/zena/use/zafu_safe_definitions.rb +91 -9
- data/lib/zena/use/zafu_templates.rb +146 -102
- data/lib/zena/use/zazen.rb +5 -4
- data/lib/zena/zafu_compiler.rb +1 -0
- data/locale/en/LC_MESSAGES/zena.mo +0 -0
- data/locale/en/zena.po +0 -1
- data/locale/fr/LC_MESSAGES/zena.mo +0 -0
- data/locale/fr/zena.mo +0 -0
- data/locale/fr/zena.po +4 -4
- data/misc/zena +35 -0
- data/misc/zena_init +41 -0
- data/public/images/ext/{basecontact.png → contact.png} +0 -0
- data/public/javascripts/zena.js +35 -7
- data/public/stylesheets/admin.css +5 -2
- data/public/stylesheets/default.css +2 -1
- data/public/stylesheets/popup.css +1 -1
- data/public/stylesheets/zena.css +2 -2
- data/test/custom_queries/complex.host.yml +12 -5
- data/test/fixtures/files/Node-test.zafu +3 -3
- data/test/fixtures/files/translations_fr.yml +4 -2
- data/test/functional/documents_controller_test.rb +31 -0
- data/test/functional/nodes_controller_commit_test.rb +1 -5
- data/test/functional/nodes_controller_test.rb +92 -12
- data/test/functional/user_sessions_controller_test.rb +2 -2
- data/test/functional/users_controller_test.rb +31 -29
- data/test/functional/versions_controller_test.rb +2 -2
- data/test/functional/virtual_classes_controller_test.rb +2 -2
- data/test/integration/multiple_hosts_test.rb +19 -8
- data/test/integration/navigation_test.rb +91 -12
- data/test/integration/query_node/basic.yml +40 -37
- data/test/integration/query_node/complex.yml +23 -18
- data/test/integration/query_node/dates.yml +3 -3
- data/test/integration/query_node/errors.yml +7 -1
- data/test/integration/query_node/filters.yml +41 -35
- data/test/integration/query_node/idx_fields.yml +11 -0
- data/test/integration/query_node/idx_key_value.yml +77 -0
- data/test/integration/query_node/idx_scope.yml +33 -0
- data/test/integration/query_node/relations.yml +13 -13
- data/test/integration/query_node_test.rb +6 -10
- data/test/integration/zafu_compiler/action.yml +19 -6
- data/test/integration/zafu_compiler/ajax.yml +111 -51
- data/test/integration/zafu_compiler/apphelper.yml +1 -1
- data/test/integration/zafu_compiler/asset.yml +1 -1
- data/test/integration/zafu_compiler/basic.yml +42 -52
- data/test/integration/zafu_compiler/calendar.yml +3 -3
- data/test/integration/zafu_compiler/complex.yml +16 -16
- data/test/integration/zafu_compiler/complex_ok.yml +2 -2
- data/test/integration/zafu_compiler/conditional.yml +42 -33
- data/test/integration/zafu_compiler/data.yml +3 -3
- data/test/integration/zafu_compiler/dates.yml +25 -10
- data/test/integration/zafu_compiler/display.yml +49 -12
- data/test/integration/zafu_compiler/errors.yml +26 -6
- data/test/integration/zafu_compiler/eval.yml +4 -4
- data/test/integration/zafu_compiler/forms.yml +89 -15
- data/test/integration/zafu_compiler/i18n.yml +23 -18
- data/test/integration/zafu_compiler/idx_scope.yml +7 -0
- data/test/integration/zafu_compiler/later.yml +10 -16
- data/test/integration/zafu_compiler/off/off.yml +2 -2
- data/test/integration/zafu_compiler/query.yml +207 -0
- data/test/integration/zafu_compiler/recursion.yml +2 -2
- data/test/integration/zafu_compiler/relations.yml +144 -168
- data/test/integration/zafu_compiler/roles.yml +86 -10
- data/test/integration/zafu_compiler/rubyless.yml +49 -6
- data/test/integration/zafu_compiler/safe_definitions.yml +35 -6
- data/test/integration/zafu_compiler/search.yml +1 -1
- data/test/integration/zafu_compiler/security.yml +37 -0
- data/test/integration/zafu_compiler/urls.yml +50 -40
- data/test/integration/zafu_compiler/user.yml +21 -6
- data/test/integration/zafu_compiler/version.yml +6 -6
- data/test/integration/zafu_compiler/zafu_attributes.yml +43 -34
- data/test/integration/zafu_compiler/zazen.yml +10 -10
- data/test/integration/zafu_compiler_test.rb +19 -13
- data/test/sites/complex/nodes.yml +0 -2
- data/test/sites/complex/roles.yml +9 -1
- data/test/sites/complex/sites.yml +0 -1
- data/test/sites/complex/users.yml +2 -5
- data/test/sites/ocean/nodes.yml +2 -5
- data/test/sites/ocean/roles.yml +8 -0
- data/test/sites/ocean/sites.yml +0 -1
- data/test/sites/ocean/users.yml +0 -13
- data/test/sites/zena/columns.yml +27 -5
- data/test/sites/zena/idx_projects.yml +5 -0
- data/test/sites/zena/nodes.yml +8 -32
- data/test/sites/zena/relations.yml +5 -0
- data/test/sites/zena/roles.yml +25 -3
- data/test/sites/zena/sites.yml +2 -2
- data/test/sites/zena/users.yml +1 -21
- data/test/sites/zena/versions.yml +35 -12
- data/test/test_helper.rb +7 -0
- data/test/unit/after_commit_test.rb +7 -7
- data/test/unit/cache_test.rb +32 -0
- data/test/unit/cached_page_test.rb +1 -1
- data/test/unit/column_test.rb +31 -7
- data/test/unit/comment_test.rb +2 -2
- data/test/unit/core_ext_test.rb +38 -7
- data/test/unit/document_test.rb +14 -42
- data/test/unit/node_test.rb +311 -324
- data/test/unit/note_test.rb +23 -31
- data/test/unit/page_test.rb +16 -58
- data/test/unit/project_test.rb +2 -2
- data/test/unit/relation_proxy_test.rb +148 -21
- data/test/unit/relation_test.rb +23 -3
- data/test/unit/remote_test.rb +15 -9
- data/test/unit/role_test.rb +9 -0
- data/test/unit/site_test.rb +49 -47
- data/test/unit/skin_test.rb +16 -0
- data/test/unit/template_test.rb +60 -69
- data/test/unit/text_document_test.rb +15 -14
- data/test/unit/user_test.rb +101 -41
- data/test/unit/version_test.rb +4 -4
- data/test/unit/virtual_class_test.rb +577 -36
- data/test/unit/workflow_test.rb +58 -21
- data/test/unit/zena/acts/enrollable_test.rb +36 -127
- data/test/unit/zena/acts/secure_test.rb +6 -22
- data/test/unit/zena/acts/serializable_test.rb +18 -0
- data/test/unit/zena/db_test.rb +14 -14
- data/test/unit/zena/parser/zafu.yml +5 -3
- data/test/unit/zena/use/ancestry_test.rb +198 -0
- data/test/unit/zena/use/calendar_test.rb +8 -8
- data/test/unit/zena/use/dates_test.rb +2 -0
- data/test/unit/zena/use/fulltext_test.rb +9 -1
- data/test/unit/zena/use/html_tags_test.rb +2 -16
- data/test/unit/zena/use/i18n_test.rb +2 -2
- data/test/unit/zena/use/kpath_test.rb +13 -0
- data/test/unit/zena/use/ml_index_test.rb +60 -12
- data/test/unit/zena/use/prop_eval_test.rb +170 -0
- data/test/unit/zena/use/query_node_test.rb +9 -2
- data/test/unit/zena/use/rendering_test.rb +98 -1
- data/test/unit/zena/use/scope_index_test.rb +464 -0
- data/test/unit/zena/use/urls_test.rb +23 -13
- data/test/unit/zena/use/version_hash_test.rb +2 -2
- data/test/unit/zena/use/zafu_template_test.rb +21 -8
- data/test/unit/zena/use/zazen_test.rb +47 -47
- data/zena.gemspec +177 -143
- metadata +222 -141
- data/app/models/base_contact.rb +0 -79
- data/app/models/book.rb +0 -242
- data/app/models/contact_content.rb +0 -70
- data/app/models/contact_version.rb +0 -40
- data/app/models/reference.rb +0 -18
- data/app/views/templates/edit_tabs/_basecontact.rhtml +0 -8
- data/bricks/data2pdf/README +0 -19
- data/bricks/data2pdf/VERSION +0 -1
- data/bricks/data2pdf/lib/data2pdf.rb +0 -60
- data/bricks/data2pdf/lib/engines/prince.rb +0 -39
- data/bricks/data2pdf/lib/engines/xhtml2pdf.rb +0 -41
- data/bricks/data2pdf/lib/install.rb +0 -111
- data/bricks/data2pdf/test/engines/test_prince.rb +0 -14
- data/bricks/data2pdf/test/engines/test_xhtml2pdf.rb +0 -14
- data/bricks/data2pdf/test/shoulda_macros/shoulda_data2pdf.rb +0 -91
- data/bricks/data2pdf/test/unit/test_rendering.rb +0 -37
- data/config/routes.rb +0 -3
- data/db/migrate/010_create_template_content.rb +0 -17
- data/db/migrate/024_correct_vclass_kpath.rb +0 -13
- data/db/migrate/025_move_tag_into_vclass.rb +0 -15
- data/lib/version_off.rb +0 -323
- data/lib/zena/use/node_name.rb +0 -94
- data/test/integration/query_node/properties.yml +0 -41
- data/test/unit/base_contact_test.rb +0 -242
- data/test/unit/node_name_test.rb +0 -137
@@ -26,11 +26,11 @@ class UserSessionsControllerTest < Zena::Controller::TestCase
|
|
26
26
|
context "with login Test Case" do
|
27
27
|
|
28
28
|
setup do
|
29
|
-
login('
|
29
|
+
login('lion')
|
30
30
|
end
|
31
31
|
|
32
32
|
should "visitor be accessible" do
|
33
|
-
assert_equal '
|
33
|
+
assert_equal 'lion', visitor.login
|
34
34
|
end
|
35
35
|
|
36
36
|
should "site be accessible" do
|
@@ -2,10 +2,10 @@ require 'test_helper'
|
|
2
2
|
|
3
3
|
class UsersControllerTest < Zena::Controller::TestCase
|
4
4
|
|
5
|
-
context "
|
6
|
-
context "
|
5
|
+
context "Accessing index" do
|
6
|
+
context "with an admin user" do
|
7
7
|
setup do
|
8
|
-
login(:
|
8
|
+
login(:lion)
|
9
9
|
get :index
|
10
10
|
end
|
11
11
|
|
@@ -14,7 +14,7 @@ class UsersControllerTest < Zena::Controller::TestCase
|
|
14
14
|
should_respond_with :success
|
15
15
|
end
|
16
16
|
|
17
|
-
context "
|
17
|
+
context "with a regular user" do
|
18
18
|
setup do
|
19
19
|
login(:ant)
|
20
20
|
get :index
|
@@ -25,24 +25,27 @@ class UsersControllerTest < Zena::Controller::TestCase
|
|
25
25
|
should_respond_with 404
|
26
26
|
end
|
27
27
|
|
28
|
-
context "
|
28
|
+
context "with an invalid layout" do
|
29
29
|
setup do
|
30
30
|
login(:lion)
|
31
|
-
|
31
|
+
# Make a bad admin layout
|
32
|
+
Version.connection.execute "UPDATE #{Version.table_name} SET properties = '{\"data\":{\"title\":\"foo\",\"text\":\"empty\"},\"json_class\":\"Property::Properties\"}' WHERE id = #{versions_id(:Node_admin_layout_zafu_en)}"
|
32
33
|
without_files('test.host/zafu') do
|
34
|
+
get 'index'
|
33
35
|
get 'index'
|
34
36
|
end
|
35
37
|
end
|
36
38
|
|
37
39
|
should_respond_with :success
|
40
|
+
# Renders with default layout "default/Node-+adminLayout.zafu" => compilation as "_main"
|
38
41
|
should_render_with_layout :_main
|
39
42
|
end
|
40
43
|
|
41
44
|
end
|
42
45
|
|
43
|
-
context "
|
46
|
+
context "Accessing a user" do
|
44
47
|
setup do
|
45
|
-
login(:
|
48
|
+
login(:lion)
|
46
49
|
get(:show, {'id'=>visitor.id})
|
47
50
|
end
|
48
51
|
|
@@ -84,18 +87,21 @@ class UsersControllerTest < Zena::Controller::TestCase
|
|
84
87
|
subject do
|
85
88
|
{
|
86
89
|
:user => {
|
87
|
-
'name' => 'Dupont',
|
88
90
|
'lang' => 'fr',
|
89
91
|
'time_zone' => 'Europe/Zurich',
|
90
|
-
|
92
|
+
'status' => '50',
|
91
93
|
'password' => 'secret',
|
92
94
|
'login' => 'bolomey',
|
93
|
-
'first_name' => 'Paul',
|
94
95
|
'group_ids' => [groups_id(:admin), ''],
|
96
|
+
'infamous' => '' # This is to test bad blank values
|
97
|
+
},
|
98
|
+
'_' => '', # This is in the original post
|
99
|
+
:action => 'create',
|
100
|
+
:node => {
|
101
|
+
'name' => 'Dupont',
|
102
|
+
'first_name' => 'Paul',
|
95
103
|
'email' => 'paul.bolomey@brainfuck.com',
|
96
|
-
'_' => '' # This is in the original post
|
97
104
|
},
|
98
|
-
:action => 'create'
|
99
105
|
}
|
100
106
|
end
|
101
107
|
|
@@ -121,9 +127,9 @@ class UsersControllerTest < Zena::Controller::TestCase
|
|
121
127
|
end # With an admin user
|
122
128
|
|
123
129
|
|
124
|
-
context '
|
130
|
+
context 'Accessing preferences' do
|
125
131
|
setup do
|
126
|
-
login(:
|
132
|
+
login(:ant)
|
127
133
|
get(:preferences, {'id'=>visitor.id})
|
128
134
|
end
|
129
135
|
|
@@ -131,19 +137,15 @@ class UsersControllerTest < Zena::Controller::TestCase
|
|
131
137
|
should_render_with_layout :_main
|
132
138
|
end
|
133
139
|
|
134
|
-
context "
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
put 'update', 'id' => users_id(:lion), 'user'=>{'name'=>'Leo Verneyi', 'lang'=>'en', 'time_zone'=>'Africa/Algiers', 'first_name'=>'Panthera', 'login'=>'lion', 'email'=>'lion@zenadmin.info'}
|
139
|
-
end
|
140
|
-
should_assign_to :user
|
141
|
-
should_respond_with :success
|
142
|
-
should "be able to set timezone" do
|
143
|
-
assert_equal 'Africa/Algiers', assigns(:user)[:time_zone]
|
144
|
-
end
|
140
|
+
context "Updating a user" do
|
141
|
+
setup do
|
142
|
+
login(:lion)
|
143
|
+
put 'update', 'id' => users_id(:lion), 'user'=>{'name'=>'Leo Verneyi', 'lang'=>'en', 'time_zone'=>'Africa/Algiers', 'first_name'=>'Panthera', 'login'=>'lion', 'email'=>'lion@zenadmin.info'}
|
145
144
|
end
|
146
|
-
|
147
|
-
|
148
|
-
|
145
|
+
should_assign_to :user
|
146
|
+
should_respond_with :success
|
147
|
+
should "be able to set timezone" do
|
148
|
+
assert_equal 'Africa/Algiers', assigns(:user)[:time_zone]
|
149
|
+
end
|
150
|
+
end # Updating a user
|
149
151
|
end
|
@@ -27,7 +27,7 @@ class VersionsControllerTest < Zena::Controller::TestCase
|
|
27
27
|
should 'get a page rendered with zafu when getting a version' do
|
28
28
|
get 'show', version_hash(:lake_red_en)
|
29
29
|
assert_response :success
|
30
|
-
assert_match %r{
|
30
|
+
assert_match %r{Default skin/Node/fr/_main.erb$}, @response.rendered[:template].to_s
|
31
31
|
end
|
32
32
|
end
|
33
33
|
|
@@ -78,7 +78,7 @@ class VersionsControllerTest < Zena::Controller::TestCase
|
|
78
78
|
start =<<-END_CSS
|
79
79
|
body { font-size:10px; }
|
80
80
|
#header { background:url('bird.jpg') }
|
81
|
-
#footer { background:url('/projects/wiki/flower.jpg') }
|
81
|
+
#footer { background:url('/projects list/a wiki with Zena/flower.jpg') }
|
82
82
|
END_CSS
|
83
83
|
|
84
84
|
assert node.update_attributes(:text => start.dup)
|
@@ -62,7 +62,7 @@ class VirtualClassesControllerTest < Zena::Controller::TestCase
|
|
62
62
|
post_subject
|
63
63
|
vclass = assigns(:virtual_class)
|
64
64
|
assert_equal 'Xkcd', vclass.name
|
65
|
-
assert_equal Section, vclass.superclass
|
65
|
+
assert_equal VirtualClass['Section'], vclass.superclass
|
66
66
|
assert_equal 'NPSX', vclass.kpath
|
67
67
|
end
|
68
68
|
|
@@ -90,7 +90,7 @@ class VirtualClassesControllerTest < Zena::Controller::TestCase
|
|
90
90
|
post_subject
|
91
91
|
vclass = assigns(:virtual_class)
|
92
92
|
assert_equal 'Xkcd', vclass.name
|
93
|
-
assert_equal Section, vclass.superclass
|
93
|
+
assert_equal VirtualClass['Section'], vclass.superclass
|
94
94
|
assert_equal 'NPS', vclass.kpath
|
95
95
|
end
|
96
96
|
|
@@ -20,9 +20,9 @@ class MultipleHostsTest < ActionController::IntegrationTest
|
|
20
20
|
assert_equal 'ocean.host', visitor.site.host
|
21
21
|
Node.connection.execute "UPDATE nodes set zip = 11114 where id = #{nodes(:ocean, :whale)[:id]}" # whale
|
22
22
|
Node.connection.execute "UPDATE nodes set zip = 11114 where id = #{nodes(:zena, :tiger)[:id]}" # tiger
|
23
|
-
anon.get "http://ocean.host/en/
|
23
|
+
anon.get "http://ocean.host/en/contact11114.html" # zip 11114 ==> whale
|
24
24
|
assert_equal nodes(:ocean, :whale)[:id], anon.assigns(:node)[:id]
|
25
|
-
anon.get "http://test.host/en/
|
25
|
+
anon.get "http://test.host/en/contact11114.html" # zip 11114 ==> tiger
|
26
26
|
assert_equal nodes(:zena, :tiger)[:id], anon.assigns(:node)[:id]
|
27
27
|
end
|
28
28
|
|
@@ -35,21 +35,25 @@ class MultipleHostsTest < ActionController::IntegrationTest
|
|
35
35
|
end
|
36
36
|
|
37
37
|
def test_cache
|
38
|
-
|
38
|
+
# We need the visitor to load VirtualClass cache.
|
39
|
+
Thread.current[:visitor] = users(:anon)
|
40
|
+
node_zip = nodes(:zena, :people).zip
|
41
|
+
Thread.current[:visitor] = nil
|
42
|
+
|
39
43
|
without_files('/test.host/public') do
|
40
44
|
with_caching do
|
41
|
-
path = "/en/
|
45
|
+
path = "/en/section#{node_zip}.html"
|
42
46
|
filepath = "#{RAILS_ROOT}/sites/test.host/public#{path}"
|
43
47
|
assert !File.exist?(filepath)
|
44
48
|
anon.get "http://test.host#{path}"
|
45
49
|
assert_equal 200, anon.status
|
46
50
|
assert File.exist?(filepath), "Cache file created"
|
47
|
-
node = nodes(:zena, :
|
48
|
-
assert_equal 1, CachedPage.count(:conditions => "path like '%
|
51
|
+
node = nodes(:zena, :people)
|
52
|
+
assert_equal 1, CachedPage.count(:conditions => "path like '%section#{node_zip}%'")
|
49
53
|
assert_not_equal 0, Zena::Db.fetch_attribute("SELECT COUNT(*) as count_all FROM cached_pages_nodes WHERE node_id = #{node[:id]}").to_i
|
50
54
|
node.visitor = Thread.current[:visitor]
|
51
55
|
node.sweep_cache
|
52
|
-
assert_equal 0, CachedPage.count(:conditions => "path like '%
|
56
|
+
assert_equal 0, CachedPage.count(:conditions => "path like '%section#{node_zip}%'")
|
53
57
|
assert_equal 0, Zena::Db.fetch_attribute("SELECT COUNT(*) as count_all FROM cached_pages_nodes WHERE node_id = #{node[:id]}").to_i
|
54
58
|
assert !File.exist?(filepath)
|
55
59
|
end
|
@@ -78,7 +82,14 @@ class MultipleHostsTest < ActionController::IntegrationTest
|
|
78
82
|
if @node[:id] == @site.root_id
|
79
83
|
name = []
|
80
84
|
else
|
81
|
-
name =
|
85
|
+
name = case node_sym
|
86
|
+
when :wiki
|
87
|
+
'blog29.html'
|
88
|
+
when :status
|
89
|
+
'page22.html'
|
90
|
+
else
|
91
|
+
raise 'Please set page in get_node.'
|
92
|
+
end
|
82
93
|
end
|
83
94
|
prefix = (!request || session[:user] == @site.anon_id) ? 'en' : AUTHENTICATED_PREFIX
|
84
95
|
url = "http://#{host}/#{prefix}/#{name}"
|
@@ -38,6 +38,72 @@ class NavigationTest < Zena::Integration::TestCase
|
|
38
38
|
assert_redirected_to "http://test.host/oo"
|
39
39
|
end
|
40
40
|
|
41
|
+
context 'Asset rendering' do
|
42
|
+
setup do
|
43
|
+
post 'http://test.host/session', :login=>'tiger', :password=>'tiger'
|
44
|
+
@visitor = users(:tiger)
|
45
|
+
Thread.current[:visitor] = nil
|
46
|
+
end
|
47
|
+
|
48
|
+
context 'with valid http auth' do
|
49
|
+
setup do
|
50
|
+
@headers = {
|
51
|
+
'HTTP_AUTHORIZATION' => 'Basic ' + Base64::encode64("#{@visitor.id}:#{@visitor.persistence_token}")
|
52
|
+
}
|
53
|
+
end
|
54
|
+
|
55
|
+
subject do
|
56
|
+
[
|
57
|
+
"http://localhost:1234/oo/project19.html",
|
58
|
+
{},
|
59
|
+
@headers
|
60
|
+
]
|
61
|
+
end
|
62
|
+
|
63
|
+
should 'set host and login wth given user' do
|
64
|
+
reset!
|
65
|
+
get *subject
|
66
|
+
assert_response :success
|
67
|
+
assert users_id(:tiger), visitor.id
|
68
|
+
assert_match %r{Secret}, response.body
|
69
|
+
end
|
70
|
+
|
71
|
+
context 'but invalid host' do
|
72
|
+
subject do
|
73
|
+
[
|
74
|
+
"http://test.host:1234/oo/project19.html",
|
75
|
+
{},
|
76
|
+
@headers
|
77
|
+
]
|
78
|
+
|
79
|
+
end
|
80
|
+
|
81
|
+
should 'redirect to login' do
|
82
|
+
reset!
|
83
|
+
get *subject
|
84
|
+
assert_response :redirect
|
85
|
+
assert_redirected_to 'http://test.host/login'
|
86
|
+
assert_equal users_id(:anon), visitor.id
|
87
|
+
end
|
88
|
+
end # but invalid host
|
89
|
+
end # with a valid http auth
|
90
|
+
end # With render_token in url
|
91
|
+
|
92
|
+
context 'Rescue template rendering' do
|
93
|
+
setup do
|
94
|
+
post 'http://test.host/session', :login=>'lion', :password=>'lion'
|
95
|
+
get 'http://test.host/rescue'
|
96
|
+
@visitor = users(:tiger)
|
97
|
+
Thread.current[:visitor] = nil
|
98
|
+
end
|
99
|
+
|
100
|
+
should 'render home page' do
|
101
|
+
get 'http://test.host/oo'
|
102
|
+
assert_response :success
|
103
|
+
end
|
104
|
+
end # Rescue template rendering
|
105
|
+
|
106
|
+
|
41
107
|
# HTTP_AUTH disabled
|
42
108
|
# def test_authorize_http_auth
|
43
109
|
# Site.connection.execute "UPDATE sites SET http_auth = 1 WHERE id = #{sites_id(:zena)}"
|
@@ -71,8 +137,8 @@ class NavigationTest < Zena::Integration::TestCase
|
|
71
137
|
assert_redirected_to "http://test.host/oo"
|
72
138
|
# 2. navigating out of '/oo' but logged in and format is not data, custom_base url (format not in path)
|
73
139
|
assert_equal 'en', session[:lang]
|
74
|
-
get 'http://test.host/fr/
|
75
|
-
assert_redirected_to 'http://test.host/oo/
|
140
|
+
get 'http://test.host/fr/page18.html'
|
141
|
+
assert_redirected_to 'http://test.host/oo/page18.html'
|
76
142
|
assert_equal 'fr', session[:lang]
|
77
143
|
follow_redirect!
|
78
144
|
assert_response :success
|
@@ -189,6 +255,11 @@ class NavigationTest < Zena::Integration::TestCase
|
|
189
255
|
assert_equal 'fr', session[:lang]
|
190
256
|
end
|
191
257
|
|
258
|
+
def test_url_with_custom_base
|
259
|
+
get 'http://test.host/en/projects-list/Clean-Water-project'
|
260
|
+
assert_response :success
|
261
|
+
end
|
262
|
+
|
192
263
|
def test_nodes_redirect
|
193
264
|
get 'http://test.host/nodes/30'
|
194
265
|
assert_redirected_to 'http://test.host/en/image30.html'
|
@@ -197,22 +268,22 @@ class NavigationTest < Zena::Integration::TestCase
|
|
197
268
|
end
|
198
269
|
|
199
270
|
def test_url_without_lang_redirect
|
200
|
-
get 'http://test.host/
|
201
|
-
assert_redirected_to 'http://test.host/en/
|
271
|
+
get 'http://test.host/blog29.html'
|
272
|
+
assert_redirected_to 'http://test.host/en/blog29.html'
|
202
273
|
follow_redirect!
|
203
274
|
assert_response :success
|
204
275
|
end
|
205
276
|
|
206
277
|
def test_url_without_lang_redirect_keeps_url_params
|
207
|
-
get 'http://test.host/
|
208
|
-
assert_redirected_to 'http://test.host/en/
|
278
|
+
get 'http://test.host/blog29.html?page=2'
|
279
|
+
assert_redirected_to 'http://test.host/en/blog29.html?page=2'
|
209
280
|
follow_redirect!
|
210
281
|
assert_response :success
|
211
282
|
end
|
212
283
|
|
213
284
|
def test_url_bad_class_redirect_keeps_url_params
|
214
285
|
get 'http://test.host/en/page29.html?page=2'
|
215
|
-
assert_redirected_to 'http://test.host/en/
|
286
|
+
assert_redirected_to 'http://test.host/en/blog29.html?page=2'
|
216
287
|
follow_redirect!
|
217
288
|
assert_response :success
|
218
289
|
end
|
@@ -221,16 +292,16 @@ class NavigationTest < Zena::Integration::TestCase
|
|
221
292
|
get 'http://test.host/29'
|
222
293
|
assert_redirected_to 'http://test.host/en/29'
|
223
294
|
follow_redirect!
|
224
|
-
assert_redirected_to 'http://test.host/en/
|
295
|
+
assert_redirected_to 'http://test.host/en/blog29.html'
|
225
296
|
follow_redirect!
|
226
297
|
assert_response :success
|
227
298
|
end
|
228
299
|
|
229
300
|
def test_url_by_path_without_lang_redirect
|
230
|
-
get 'http://test.host/
|
231
|
-
assert_redirected_to 'http://test.host/en/
|
301
|
+
get 'http://test.host/people'
|
302
|
+
assert_redirected_to 'http://test.host/en/people'
|
232
303
|
follow_redirect!
|
233
|
-
assert_redirected_to 'http://test.host/en/
|
304
|
+
assert_redirected_to 'http://test.host/en/section12.html'
|
234
305
|
follow_redirect!
|
235
306
|
assert_response :success
|
236
307
|
end
|
@@ -240,6 +311,14 @@ class NavigationTest < Zena::Integration::TestCase
|
|
240
311
|
assert_response :missing
|
241
312
|
end
|
242
313
|
|
314
|
+
def test_bad_url_without_notFound_template
|
315
|
+
$_test_site = 'zena'
|
316
|
+
Node.connection.execute "UPDATE nodes SET kpath='N' where id = #{nodes_id(:Node_not_found_zafu)}"
|
317
|
+
post 'http://test.host/session', :login=>'tiger', :password=>'tiger'
|
318
|
+
get 'http://test.host/oo/node1.html'
|
319
|
+
assert_response :missing
|
320
|
+
end
|
321
|
+
|
243
322
|
def test_bad_zip
|
244
323
|
get 'http://test.host/1'
|
245
324
|
assert_redirected_to 'http://test.host/en/1'
|
@@ -272,7 +351,7 @@ class NavigationTest < Zena::Integration::TestCase
|
|
272
351
|
def test_show_with_mode
|
273
352
|
get "http://test.host/en/section12_changes.html"
|
274
353
|
assert_response :missing # people is not rendered with 'wiki' mode where 'changes' is defined.
|
275
|
-
get "http://test.host/en/
|
354
|
+
get "http://test.host/en/blog29_changes.html"
|
276
355
|
assert_response :success
|
277
356
|
get 'http://test.host/en/section12_index.html'
|
278
357
|
assert_response :missing
|
@@ -4,39 +4,39 @@ default:
|
|
4
4
|
node: 'cleanWater'
|
5
5
|
visitor: 'ant'
|
6
6
|
src: ""
|
7
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.
|
8
|
-
res: "
|
7
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.zip ASC}, @node.id]"
|
8
|
+
res: "Etat des travaux, The lake we love, it's a lake, water, crocodiles, super ouverture, Keeping things clean !"
|
9
9
|
|
10
10
|
nodes:
|
11
11
|
src: "nodes"
|
12
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.
|
12
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.zip ASC}, @node.id]"
|
13
13
|
|
14
14
|
pages:
|
15
15
|
src: "pages"
|
16
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.kpath LIKE 'NP%' AND nodes.parent_id = ? ORDER BY nodes.
|
17
|
-
res: "
|
16
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.kpath LIKE 'NP%' AND nodes.parent_id = ? ORDER BY nodes.zip ASC}, @node.id]"
|
17
|
+
res: "Etat des travaux, crocodiles, Keeping things clean !"
|
18
18
|
|
19
19
|
letters:
|
20
20
|
src: "letters"
|
21
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.kpath LIKE 'NNL%' AND nodes.parent_id = ? ORDER BY nodes.
|
21
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.kpath LIKE 'NNL%' AND nodes.parent_id = ? ORDER BY nodes.zip ASC}, @node.id]"
|
22
22
|
|
23
23
|
nodes_in_site:
|
24
|
-
sql: "%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} ORDER BY nodes.
|
24
|
+
sql: "%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} ORDER BY nodes.zip ASC}"
|
25
25
|
|
26
26
|
pages_in_project:
|
27
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.kpath LIKE 'NP%' AND nodes.project_id = ? ORDER BY nodes.
|
27
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.kpath LIKE 'NP%' AND nodes.project_id = ? ORDER BY nodes.zip ASC}, @node.get_project_id]"
|
28
28
|
|
29
29
|
nodes_in_section:
|
30
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.section_id = ? ORDER BY nodes.
|
30
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.section_id = ? ORDER BY nodes.zip ASC}, @node.get_section_id]"
|
31
31
|
|
32
32
|
nodes_in_self:
|
33
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.
|
33
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.zip ASC}, @node.id]"
|
34
34
|
|
35
35
|
nodes_in_parent:
|
36
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.
|
36
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.zip ASC}, @node.parent_id]"
|
37
37
|
|
38
38
|
children:
|
39
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.
|
39
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.zip ASC}, @node.id]"
|
40
40
|
|
41
41
|
# --- fixed up to here
|
42
42
|
|
@@ -44,80 +44,83 @@ pages_or_letters:
|
|
44
44
|
context:
|
45
45
|
node: zena
|
46
46
|
src: pages or letters
|
47
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND ((nodes.kpath LIKE 'NP%' AND nodes.parent_id = ?) OR (nodes.kpath LIKE 'NNL%' AND nodes.parent_id = ?)) GROUP BY id ORDER BY nodes.
|
48
|
-
res: "
|
47
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND ((nodes.kpath LIKE 'NP%' AND nodes.parent_id = ?) OR (nodes.kpath LIKE 'NNL%' AND nodes.parent_id = ?)) GROUP BY id ORDER BY nodes.zip ASC}, @node.id, @node.id]"
|
48
|
+
res: "people, projects list, Collections, Nature, zena enhancements, Skins (layout themes)"
|
49
49
|
|
50
50
|
project:
|
51
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.id = ? ORDER BY nodes.
|
52
|
-
res: '
|
51
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.id = ? ORDER BY nodes.zip ASC}, @node.get_project_id]"
|
52
|
+
res: 'Clean Water project'
|
53
53
|
|
54
54
|
many_alternatives:
|
55
55
|
src: tagged in site or images in site or tags in site
|
56
|
-
sql: "%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND ((nodes.id = links.source_id AND links.relation_id = _ID(node_has_tags)) OR (nodes.kpath LIKE 'NDI%' AND links.id = 0) OR (nodes.kpath LIKE 'NPT%' AND links.id = 0)) GROUP BY nodes.id ORDER BY nodes.
|
57
|
-
# res:
|
56
|
+
sql: "%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND ((nodes.id = links.source_id AND links.relation_id = _ID(node_has_tags)) OR (nodes.kpath LIKE 'NDI%' AND links.id = 0) OR (nodes.kpath LIKE 'NPT%' AND links.id = 0)) GROUP BY nodes.id ORDER BY nodes.zip ASC}"
|
57
|
+
# res: "art, bird, Clean Water project, flower, it's a lake, menu, news, opening, tree"
|
58
58
|
|
59
59
|
alternatives_same_join:
|
60
60
|
src: tagged in site or icons
|
61
|
-
sql: "[%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND ((nodes.id = links.source_id AND links.relation_id = _ID(node_has_tags)) OR (nodes.id = links.target_id AND links.relation_id = _ID(node_has_an_icon) AND links.source_id = ?)) GROUP BY nodes.id ORDER BY nodes.
|
62
|
-
res: "
|
61
|
+
sql: "[%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND ((nodes.id = links.source_id AND links.relation_id = _ID(node_has_tags)) OR (nodes.id = links.target_id AND links.relation_id = _ID(node_has_an_icon) AND links.source_id = ?)) GROUP BY nodes.id ORDER BY nodes.zip ASC}, @node.id]"
|
62
|
+
res: "Clean Water project, it's a lake, super ouverture"
|
63
63
|
|
64
64
|
same_name_as_class:
|
65
65
|
context:
|
66
66
|
node: 'opening'
|
67
67
|
src: "set_tags"
|
68
|
-
sql: "[%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND nodes.id = links.target_id AND links.relation_id = _ID(node_has_tags) AND links.source_id = ? ORDER BY nodes.
|
69
|
-
res: "
|
68
|
+
sql: "[%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND nodes.id = links.target_id AND links.relation_id = _ID(node_has_tags) AND links.source_id = ? ORDER BY nodes.zip ASC}, @node.id]"
|
69
|
+
res: "Art, News list"
|
70
70
|
|
71
71
|
|
72
72
|
notes_in_project:
|
73
|
-
res: "
|
73
|
+
res: "super ouverture"
|
74
74
|
|
75
75
|
vclass_in_project:
|
76
76
|
src: "posts in project"
|
77
|
-
res: "
|
77
|
+
res: "super ouverture"
|
78
78
|
|
79
79
|
vlcass_or_pages:
|
80
80
|
src: "(posts in project) or pages"
|
81
|
-
res: "
|
81
|
+
res: "Etat des travaux, crocodiles, super ouverture, Keeping things clean !"
|
82
82
|
|
83
83
|
find_relation:
|
84
84
|
context:
|
85
85
|
node: 'ant'
|
86
|
-
class:
|
86
|
+
class: Contact
|
87
87
|
src: "favorites"
|
88
|
-
res: "
|
88
|
+
res: "Nature"
|
89
89
|
|
90
90
|
root:
|
91
|
-
res: "
|
91
|
+
res: "Zena the wild CMS"
|
92
|
+
|
93
|
+
self:
|
94
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.id = ? ORDER BY nodes.zip ASC}, @node.id]"
|
92
95
|
|
93
96
|
children_with_order_clause:
|
94
|
-
src: "children order by
|
95
|
-
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.
|
97
|
+
src: "children order by position ASC"
|
98
|
+
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} AND nodes.parent_id = ? ORDER BY nodes.position ASC}, @node.id]"
|
96
99
|
|
97
100
|
notes_or_news:
|
98
101
|
context:
|
99
102
|
class: Project
|
100
|
-
sql: "[%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND ((nodes.kpath LIKE 'NN%' AND nodes.parent_id = ? AND links.id = 0) OR (nodes.id = links.source_id AND links.relation_id = _ID(note_has_calendars) AND links.target_id = ?)) GROUP BY nodes.id ORDER BY nodes.
|
103
|
+
sql: "[%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND ((nodes.kpath LIKE 'NN%' AND nodes.parent_id = ? AND links.id = 0) OR (nodes.id = links.source_id AND links.relation_id = _ID(note_has_calendars) AND links.target_id = ?)) GROUP BY nodes.id ORDER BY nodes.zip ASC}, @node.id, @node.id]"
|
101
104
|
|
102
105
|
news_or_notes:
|
103
106
|
context:
|
104
107
|
class: Project
|
105
|
-
sql: "[%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND ((nodes.id = links.source_id AND links.relation_id = _ID(note_has_calendars) AND links.target_id = ?) OR (nodes.kpath LIKE 'NN%' AND nodes.parent_id = ? AND links.id = 0)) GROUP BY nodes.id ORDER BY nodes.
|
108
|
+
sql: "[%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND ((nodes.id = links.source_id AND links.relation_id = _ID(note_has_calendars) AND links.target_id = ?) OR (nodes.kpath LIKE 'NN%' AND nodes.parent_id = ? AND links.id = 0)) GROUP BY nodes.id ORDER BY nodes.zip ASC}, @node.id, @node.id]"
|
106
109
|
|
107
110
|
order_l_status:
|
108
111
|
context:
|
109
112
|
node: art
|
110
113
|
class: Tag
|
111
|
-
src: "tagged order by l_status ASC,
|
112
|
-
sql: "[%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND nodes.id = links.source_id AND links.relation_id = _ID(node_has_tags) AND links.target_id = ? ORDER BY links.status ASC, nodes.
|
113
|
-
res: "
|
114
|
+
src: "tagged order by l_status ASC, zip ASC"
|
115
|
+
sql: "[%Q{SELECT nodes.*,links.id AS link_id,links.status AS l_status,links.comment AS l_comment,links.date AS l_date FROM links,nodes WHERE #{secure_scope('nodes')} AND nodes.id = links.source_id AND links.relation_id = _ID(node_has_tags) AND links.target_id = ? ORDER BY links.status ASC, nodes.zip ASC}, @node.id]"
|
116
|
+
res: "super ouverture, Clean Water project"
|
114
117
|
|
115
118
|
paginate_one:
|
116
119
|
src: "nodes in site order by zip limit 2 paginate p"
|
117
120
|
# we sort by zip to avoid collation problems when some DB sort Capital letters first
|
118
121
|
# and others are case-insensitive.
|
119
122
|
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} ORDER BY nodes.zip LIMIT 2 OFFSET ?}, ((params[:p].to_i > 0 ? params[:p].to_i : 1)-1)*2]"
|
120
|
-
res: "
|
123
|
+
res: "Zena the wild CMS, people"
|
121
124
|
|
122
125
|
paginate_two:
|
123
126
|
context:
|
@@ -125,4 +128,4 @@ paginate_two:
|
|
125
128
|
p: 2
|
126
129
|
src: "nodes in site order by zip limit 2 paginate p"
|
127
130
|
sql: "[%Q{SELECT nodes.* FROM nodes WHERE #{secure_scope('nodes')} ORDER BY nodes.zip LIMIT 2 OFFSET ?}, ((params[:p].to_i > 0 ? params[:p].to_i : 1)-1)*2]"
|
128
|
-
res: "
|
131
|
+
res: "Solenopsis Invicta, Panthera Tigris Sumatran"
|