card 0.0.1 → 1.15.pre
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.rspec +4 -0
- data/GPL +331 -0
- data/LICENSE +16 -0
- data/VERSION +1 -0
- data/card.gemspec +48 -19
- data/config/initializers/01_init_ruby_extensions.rb +7 -0
- data/config/initializers/inflections.rb +13 -0
- data/config/initializers/mime_types.rb +13 -0
- data/config/initializers/notification.rb +4 -0
- data/config/initializers/recaptcha.rb +6 -0
- data/config/initializers/uuid_state_file.rb +3 -0
- data/db/bootstrap/card_actions.yml +3872 -0
- data/db/bootstrap/card_acts.yml +7 -0
- data/db/bootstrap/card_changes.yml +11909 -0
- data/db/bootstrap/card_references.yml +3970 -0
- data/db/bootstrap/cards.yml +10805 -0
- data/db/migrate/20110511221913_require_earlier_migrations.rb +19 -0
- data/db/migrate/20120105203350_require_1_8_migrations.rb +15 -0
- data/db/migrate/20121111025347_require_1_10_migrations.rb +15 -0
- data/db/migrate/20121118114000_split_link_type.rb +16 -0
- data/db/migrate/20121118115000_update_link_type.rb +19 -0
- data/db/migrate/20130106052640_table_cleanup.rb +25 -0
- data/db/migrate/20130109015336_trunk_left.rb +14 -0
- data/db/migrate/20130411210957_update_codenames.rb +14 -0
- data/db/migrate/20140822073704_create_new_revision_tables.rb +43 -0
- data/db/migrate/20141001105348_move_revisions_to_actions.rb +62 -0
- data/db/migrate/20141121172918_rename_card_migration_table.rb +15 -0
- data/db/migrate/20141208132159_remove_present_from_reference_table.rb +9 -0
- data/db/migrate/20141216053032_better_index_names.rb +24 -0
- data/db/migrate_core_cards/20130411191151_renaming_for_menu.rb +49 -0
- data/db/migrate_core_cards/20130411211600_delete_old_related_tab_cards.rb +18 -0
- data/db/migrate_core_cards/20130419215612_import_help_text.rb +13 -0
- data/db/migrate_core_cards/20130823192433_add_style_cards.rb +87 -0
- data/db/migrate_core_cards/20130910183318_move_styles_to_content.rb +11 -0
- data/db/migrate_core_cards/20130920214038_jsonize_tinymce.rb +15 -0
- data/db/migrate_core_cards/20130920291703_update_stylesheets.rb +18 -0
- data/db/migrate_core_cards/20130927191728_account_events.rb +21 -0
- data/db/migrate_core_cards/20131016172445_common_css_patch.rb +12 -0
- data/db/migrate_core_cards/20140110193325_reset_account_request_type.rb +11 -0
- data/db/migrate_core_cards/20140307231621_user_data_to_cards.rb +73 -0
- data/db/migrate_core_cards/20140317035504_account_requests_to_signups.rb +51 -0
- data/db/migrate_core_cards/20140512155840_add_script_cards.rb +83 -0
- data/db/migrate_core_cards/20140629222005_add_email_cards.rb +134 -0
- data/db/migrate_core_cards/20140725180118_config_card_updates.rb +9 -0
- data/db/migrate_core_cards/20141111083921_delete_machine_output.rb +9 -0
- data/db/migrate_core_cards/20141115034214_config_descriptions_etc.rb +14 -0
- data/db/migrate_core_cards/20141119001955_make_symlinks_relative.rb +15 -0
- data/db/migrate_core_cards/20141120120605_fix_notification_html_message.rb +10 -0
- data/db/migrate_core_cards/20141204061304_watchers_to_following.rb +38 -0
- data/db/migrate_core_cards/20141208132416_partial_reference_type.rb +7 -0
- data/db/migrate_core_cards/20141208162106_add_ace_script.rb +12 -0
- data/db/migrate_core_cards/20141216155251_add_more_following_cards.rb +24 -0
- data/db/migrate_core_cards/20141230204340_uri_codename.rb +13 -0
- data/db/migrate_core_cards/20150202143810_import_bootstrap_layout.rb +17 -0
- data/db/migrate_core_cards/20150220134731_following_to_follow_rule.rb +18 -0
- data/db/migrate_core_cards/data/1.11_help_text.json +410 -0
- data/db/migrate_core_cards/data/1.12_stylesheets/classic_cards.scss +100 -0
- data/db/migrate_core_cards/data/1.12_stylesheets/common.scss +226 -0
- data/db/migrate_core_cards/data/1.12_stylesheets/right_sidebar.scss +27 -0
- data/db/migrate_core_cards/data/1.12_stylesheets/traditional.scss +152 -0
- data/db/migrate_core_cards/data/1.13_config_text.json +32 -0
- data/db/migrate_core_cards/data/1.14_config_descriptions_etc.json +77 -0
- data/db/migrate_core_cards/data/bootstrap_layout.json +81 -0
- data/db/migrate_core_cards/data/mailer/follower_notification_email.html +9 -0
- data/db/migrate_core_cards/data/mailer/follower_notification_email.txt +11 -0
- data/db/migrate_core_cards/data/mailer/mail_config.json +22 -0
- data/db/migrate_core_cards/data/mailer/password_reset_email.html +10 -0
- data/db/migrate_core_cards/data/mailer/password_reset_email.txt +11 -0
- data/db/migrate_core_cards/data/mailer/signup_alert_email.html +7 -0
- data/db/migrate_core_cards/data/mailer/signup_alert_email.txt +5 -0
- data/db/migrate_core_cards/data/mailer/verification_email.html +9 -0
- data/db/migrate_core_cards/data/mailer/verification_email.txt +8 -0
- data/db/schema.rb +128 -0
- data/db/seeds.rb +8 -0
- data/db/version.txt +1 -0
- data/db/version_core_cards.txt +1 -0
- data/lib/card.rb +46 -3
- data/lib/card/active_record_ext.rb +77 -0
- data/lib/card/auth.rb +181 -0
- data/lib/card/cache.rb +199 -0
- data/lib/card/chunk.rb +104 -0
- data/lib/card/codename.rb +72 -0
- data/lib/card/content.rb +211 -0
- data/lib/card/core_ext.rb +105 -0
- data/lib/card/core_migration.rb +6 -0
- data/lib/card/diff.rb +430 -0
- data/lib/card/env.rb +52 -0
- data/lib/card/exceptions.rb +44 -0
- data/lib/card/format.rb +563 -0
- data/lib/card/loader.rb +165 -0
- data/lib/card/log.rb +450 -0
- data/lib/card/mailer.rb +37 -0
- data/lib/card/migration.rb +145 -0
- data/lib/card/name.rb +45 -0
- data/lib/card/query.rb +81 -0
- data/lib/card/query/card_clause.rb +527 -0
- data/lib/card/query/clause.rb +21 -0
- data/lib/card/query/ref_clause.rb +47 -0
- data/lib/card/query/value_clause.rb +65 -0
- data/lib/card/reference.rb +63 -0
- data/lib/card/set.rb +369 -0
- data/lib/card/set_pattern.rb +168 -0
- data/lib/card/simplecov_helper.rb +61 -0
- data/lib/card/spec_helper.rb +68 -0
- data/lib/card/version.rb +9 -2
- data/lib/cardio.rb +145 -0
- data/lib/generators/card.rb +32 -0
- data/lib/generators/card/format/USAGE +9 -0
- data/lib/generators/card/format/format_generator.rb +27 -0
- data/lib/generators/card/format/templates/format_spec_template.erb +5 -0
- data/lib/generators/card/format/templates/format_template.erb +3 -0
- data/lib/generators/card/migration/USAGE +24 -0
- data/lib/generators/card/migration/migration_generator.rb +38 -0
- data/lib/generators/card/migration/templates/card_migration.erb +10 -0
- data/lib/generators/card/set/USAGE +15 -0
- data/lib/generators/card/set/set_generator.rb +29 -0
- data/lib/generators/card/set/templates/set_spec_template.erb +5 -0
- data/lib/generators/card/set/templates/set_template.erb +1 -0
- data/mod/01_core/chunk/include.rb +85 -0
- data/mod/01_core/chunk/link.rb +87 -0
- data/mod/01_core/chunk/literal.rb +24 -0
- data/mod/01_core/chunk/reference.rb +53 -0
- data/mod/01_core/chunk/uri.rb +135 -0
- data/mod/01_core/format/data_format.rb +2 -0
- data/mod/01_core/format/html_format.rb +129 -0
- data/mod/01_core/format/text_format.rb +10 -0
- data/mod/01_core/layout/blank.html +5 -0
- data/mod/01_core/layout/default.html +20 -0
- data/mod/01_core/layout/noside.html +16 -0
- data/mod/01_core/layout/pre.html +2 -0
- data/mod/01_core/layout/simple.html +5 -0
- data/mod/01_core/set/all/active_card.rb +35 -0
- data/mod/01_core/set/all/collection.rb +142 -0
- data/mod/01_core/set/all/content.rb +64 -0
- data/mod/01_core/set/all/erb.rb +11 -0
- data/mod/01_core/set/all/fetch.rb +228 -0
- data/mod/01_core/set/all/haml.rb +7 -0
- data/mod/01_core/set/all/initialize.rb +49 -0
- data/mod/01_core/set/all/name.rb +275 -0
- data/mod/01_core/set/all/pattern.rb +56 -0
- data/mod/01_core/set/all/permissions.rb +284 -0
- data/mod/01_core/set/all/phases.rb +185 -0
- data/mod/01_core/set/all/references.rb +118 -0
- data/mod/01_core/set/all/rules.rb +315 -0
- data/mod/01_core/set/all/states.rb +16 -0
- data/mod/01_core/set/all/templating.rb +120 -0
- data/mod/01_core/set/all/tracked_attributes.rb +114 -0
- data/mod/01_core/set/all/trash.rb +50 -0
- data/mod/01_core/set/all/type.rb +85 -0
- data/mod/01_core/set/all/utils.rb +85 -0
- data/mod/01_core/set_pattern/01_all.rb +11 -0
- data/mod/01_core/set_pattern/02_all_plus.rb +13 -0
- data/mod/01_core/set_pattern/03_type.rb +23 -0
- data/mod/01_core/set_pattern/04_star.rb +15 -0
- data/mod/01_core/set_pattern/05_rstar.rb +17 -0
- data/mod/01_core/set_pattern/06_right.rb +20 -0
- data/mod/01_core/set_pattern/07_type_plus_right.rb +23 -0
- data/mod/01_core/set_pattern/08_self.rb +19 -0
- data/mod/01_core/spec/chunk/literal_spec.rb +14 -0
- data/mod/01_core/spec/chunk/uri_spec.rb +292 -0
- data/mod/01_core/spec/format/data_format_spec.rb +5 -0
- data/mod/01_core/spec/format/html_format_spec.rb +140 -0
- data/mod/01_core/spec/format/text_format_spec.rb +5 -0
- data/mod/01_core/spec/set/all/active_card_spec.rb +5 -0
- data/mod/01_core/spec/set/all/attribute_tracking_spec.rb +21 -0
- data/mod/01_core/spec/set/all/collection_spec.rb +65 -0
- data/mod/01_core/spec/set/all/content_spec.rb +15 -0
- data/mod/01_core/spec/set/all/fetch_spec.rb +204 -0
- data/mod/01_core/spec/set/all/initialize_spec.rb +58 -0
- data/mod/01_core/spec/set/all/name_spec.rb +61 -0
- data/mod/01_core/spec/set/all/pattern_spec.rb +81 -0
- data/mod/01_core/spec/set/all/permissions_spec.rb +505 -0
- data/mod/01_core/spec/set/all/phases_spec.rb +6 -0
- data/mod/01_core/spec/set/all/references_spec.rb +8 -0
- data/mod/01_core/spec/set/all/rules2_spec.rb +250 -0
- data/mod/01_core/spec/set/all/rules_spec.rb +130 -0
- data/mod/01_core/spec/set/all/states_spec.rb +5 -0
- data/mod/01_core/spec/set/all/templating_spec.rb +111 -0
- data/mod/01_core/spec/set/all/tracked_attributes_spec.rb +328 -0
- data/mod/01_core/spec/set/all/trash_spec.rb +34 -0
- data/mod/01_core/spec/set/all/type_spec.rb +71 -0
- data/mod/01_core/spec/set/all/utils_spec.rb +5 -0
- data/mod/01_history/lib/card/act.rb +60 -0
- data/mod/01_history/lib/card/action.rb +176 -0
- data/mod/01_history/lib/card/change.rb +29 -0
- data/mod/01_history/set/all/actions.rb +47 -0
- data/mod/01_history/set/all/content_history.rb +131 -0
- data/mod/01_history/set/all/history.rb +296 -0
- data/mod/02_basic_types/format/css_format.rb +6 -0
- data/mod/02_basic_types/format/csv_format.rb +6 -0
- data/mod/02_basic_types/format/file_format.rb +3 -0
- data/mod/02_basic_types/format/js_format.rb +6 -0
- data/mod/02_basic_types/format/json_format.rb +6 -0
- data/mod/02_basic_types/format/rss_format.rb +11 -0
- data/mod/02_basic_types/format/xml_format.rb +6 -0
- data/mod/02_basic_types/set/all/all_css.rb +42 -0
- data/mod/02_basic_types/set/all/all_csv.rb +52 -0
- data/mod/02_basic_types/set/all/all_js.rb +7 -0
- data/mod/02_basic_types/set/all/base.rb +122 -0
- data/mod/02_basic_types/set/all/file.rb +13 -0
- data/mod/02_basic_types/set/all/json.rb +66 -0
- data/mod/02_basic_types/set/all/rss.rb +72 -0
- data/mod/02_basic_types/set/all/text.rb +8 -0
- data/mod/02_basic_types/set/type/plain_text.rb +10 -0
- data/mod/02_basic_types/set/type/pointer.rb +323 -0
- data/mod/02_basic_types/spec/set/all/all_css_spec.rb +10 -0
- data/mod/02_basic_types/spec/set/all/all_csv_spec.rb +9 -0
- data/mod/02_basic_types/spec/set/all/base_spec.rb +57 -0
- data/mod/02_basic_types/spec/set/all/file_spec.rb +5 -0
- data/mod/02_basic_types/spec/set/all/json_spec.rb +26 -0
- data/mod/02_basic_types/spec/set/all/rss_spec.rb +8 -0
- data/mod/02_basic_types/spec/set/all/text_spec.rb +5 -0
- data/mod/02_basic_types/spec/set/type/plain_text_spec.rb +11 -0
- data/mod/02_basic_types/spec/set/type/pointer_spec.rb +103 -0
- data/mod/03_machines/lib/card/machine.rb +185 -0
- data/mod/03_machines/lib/card/machine_input.rb +40 -0
- data/mod/03_machines/lib/javascript/ace.js +18204 -0
- data/mod/03_machines/lib/javascript/html5shiv-printshiv.js +1 -0
- data/mod/03_machines/lib/javascript/jquery-ui.js +14913 -0
- data/mod/03_machines/lib/javascript/jquery.autosize.js +274 -0
- data/mod/03_machines/lib/javascript/jquery.fileupload.js +1114 -0
- data/mod/03_machines/lib/javascript/jquery.iframe-transport.js +185 -0
- data/mod/03_machines/lib/javascript/jquery.js +4 -0
- data/mod/03_machines/lib/javascript/jquery.ui.autocomplete.html.js +41 -0
- data/mod/03_machines/lib/javascript/jquery_ujs.js +469 -0
- data/mod/03_machines/lib/javascript/jquerymobile.js +15454 -0
- data/mod/03_machines/lib/javascript/theme-textmate.js +130 -0
- data/mod/03_machines/lib/javascript/tinymce.js +13 -0
- data/mod/03_machines/lib/javascript/wagn.js.coffee +336 -0
- data/mod/03_machines/lib/javascript/wagn_menu.js +72 -0
- data/mod/03_machines/lib/javascript/wagn_mod.js.coffee +446 -0
- data/mod/03_machines/lib/stylesheets/functional.scss +184 -0
- data/mod/03_machines/lib/stylesheets/jquery-ui-smoothness.css +1178 -0
- data/mod/03_machines/lib/stylesheets/standard.scss +760 -0
- data/mod/03_machines/set/right/machine_output.rb +20 -0
- data/mod/03_machines/set/self/script_ace.rb +8 -0
- data/mod/03_machines/set/self/script_card_menu.rb +8 -0
- data/mod/03_machines/set/self/script_html5shiv_printshiv.rb +7 -0
- data/mod/03_machines/set/self/script_jquery.rb +8 -0
- data/mod/03_machines/set/self/script_jquery_helper.rb +14 -0
- data/mod/03_machines/set/self/script_slot.rb +9 -0
- data/mod/03_machines/set/self/script_tinymce.rb +8 -0
- data/mod/03_machines/set/self/style_functional.rb +8 -0
- data/mod/03_machines/set/self/style_jquery_ui_smoothness.rb +8 -0
- data/mod/03_machines/set/self/style_standard.rb +8 -0
- data/mod/03_machines/set/type/coffee_script.rb +61 -0
- data/mod/03_machines/set/type/css.rb +45 -0
- data/mod/03_machines/set/type/java_script.rb +38 -0
- data/mod/03_machines/set/type/scss.rb +23 -0
- data/mod/03_machines/set/type/skin.rb +12 -0
- data/mod/03_machines/spec/lib/shared_machine_examples.rb +175 -0
- data/mod/03_machines/spec/lib/shared_machine_input_examples.rb +65 -0
- data/mod/03_machines/spec/set/right/machine_output_spec.rb +5 -0
- data/mod/03_machines/spec/set/self/style_functional_spec.rb +5 -0
- data/mod/03_machines/spec/set/self/style_jquery_ui_smoothness_spec.rb +5 -0
- data/mod/03_machines/spec/set/self/style_standard_spec.rb +5 -0
- data/mod/03_machines/spec/set/type/coffeescript_spec.rb +29 -0
- data/mod/03_machines/spec/set/type/css_spec.rb +34 -0
- data/mod/03_machines/spec/set/type/javascript_spec.rb +28 -0
- data/mod/03_machines/spec/set/type/scss_spec.rb +56 -0
- data/mod/03_machines/spec/set/type/skin_spec.rb +70 -0
- data/mod/04_settings/lib/card/setting.rb +65 -0
- data/mod/04_settings/set/right/add_help.rb +11 -0
- data/mod/04_settings/set/right/comment.rb +91 -0
- data/mod/04_settings/set/right/create.rb +3 -0
- data/mod/04_settings/set/right/default.rb +3 -0
- data/mod/04_settings/set/right/delete.rb +4 -0
- data/mod/04_settings/set/right/help.rb +3 -0
- data/mod/04_settings/set/right/read.rb +2 -0
- data/mod/04_settings/set/right/script.rb +10 -0
- data/mod/04_settings/set/right/structure.rb +4 -0
- data/mod/04_settings/set/right/style.rb +10 -0
- data/mod/04_settings/set/right/update.rb +2 -0
- data/mod/04_settings/set/self/accountable.rb +3 -0
- data/mod/04_settings/set/self/add_help.rb +2 -0
- data/mod/04_settings/set/self/autoname.rb +2 -0
- data/mod/04_settings/set/self/captcha.rb +2 -0
- data/mod/04_settings/set/self/comment.rb +2 -0
- data/mod/04_settings/set/self/create.rb +2 -0
- data/mod/04_settings/set/self/default.rb +2 -0
- data/mod/04_settings/set/self/delete.rb +2 -0
- data/mod/04_settings/set/self/help.rb +2 -0
- data/mod/04_settings/set/self/input.rb +2 -0
- data/mod/04_settings/set/self/layout.rb +2 -0
- data/mod/04_settings/set/self/on_create.rb +2 -0
- data/mod/04_settings/set/self/on_delete.rb +2 -0
- data/mod/04_settings/set/self/on_update.rb +2 -0
- data/mod/04_settings/set/self/options.rb +2 -0
- data/mod/04_settings/set/self/options_label.rb +2 -0
- data/mod/04_settings/set/self/read.rb +2 -0
- data/mod/04_settings/set/self/script.rb +2 -0
- data/mod/04_settings/set/self/structure.rb +2 -0
- data/mod/04_settings/set/self/style.rb +2 -0
- data/mod/04_settings/set/self/table_of_contents.rb +2 -0
- data/mod/04_settings/set/self/thanks.rb +2 -0
- data/mod/04_settings/set/self/update.rb +2 -0
- data/mod/04_settings/set/type/setting.rb +82 -0
- data/mod/04_settings/spec/set/right/add_help_spec.rb +5 -0
- data/mod/04_settings/spec/set/right/comment_spec.rb +41 -0
- data/mod/04_settings/spec/set/right/create_spec.rb +10 -0
- data/mod/04_settings/spec/set/right/default_spec.rb +5 -0
- data/mod/04_settings/spec/set/right/delete_spec.rb +5 -0
- data/mod/04_settings/spec/set/right/help_spec.rb +5 -0
- data/mod/04_settings/spec/set/right/read_spec.rb +5 -0
- data/mod/04_settings/spec/set/right/script_spec.rb +24 -0
- data/mod/04_settings/spec/set/right/structure_spec.rb +17 -0
- data/mod/04_settings/spec/set/right/style_spec.rb +29 -0
- data/mod/04_settings/spec/set/right/update_spec.rb +5 -0
- data/mod/04_settings/spec/set/type/setting_spec.rb +10 -0
- data/mod/05_email/format/email_html_format.rb +9 -0
- data/mod/05_email/format/email_text_format.rb +11 -0
- data/mod/05_email/lib/card/follow_option.rb +90 -0
- data/mod/05_email/set/all/email_html.rb +5 -0
- data/mod/05_email/set/all/email_text.rb +5 -0
- data/mod/05_email/set/all/follow.rb +256 -0
- data/mod/05_email/set/all/notify.rb +223 -0
- data/mod/05_email/set/all/observer.rb +27 -0
- data/mod/05_email/set/right/bcc.rb +45 -0
- data/mod/05_email/set/right/cc.rb +3 -0
- data/mod/05_email/set/right/follow.rb +9 -0
- data/mod/05_email/set/right/follow_fields.rb +3 -0
- data/mod/05_email/set/right/followers.rb +30 -0
- data/mod/05_email/set/right/following.rb +52 -0
- data/mod/05_email/set/right/from.rb +3 -0
- data/mod/05_email/set/right/html_message.rb +3 -0
- data/mod/05_email/set/right/to.rb +3 -0
- data/mod/05_email/set/self/always.rb +14 -0
- data/mod/05_email/set/self/created.rb +21 -0
- data/mod/05_email/set/self/edited.rb +24 -0
- data/mod/05_email/set/self/follow.rb +2 -0
- data/mod/05_email/set/self/follow_defaults.rb +66 -0
- data/mod/05_email/set/self/never.rb +15 -0
- data/mod/05_email/set/type/email_template.rb +113 -0
- data/mod/05_email/set/type_plus_right/user/follow.rb +176 -0
- data/mod/05_email/spec/set/all/follow_spec.rb +133 -0
- data/mod/05_email/spec/set/all/notify_spec.rb +364 -0
- data/mod/05_email/spec/set/all/observer_spec.rb +76 -0
- data/mod/05_email/spec/set/right/followers_spec.rb +126 -0
- data/mod/05_email/spec/set/right/following_spec.rb +4 -0
- data/mod/05_email/spec/set/self/follow_defaults_spec.rb +18 -0
- data/mod/05_standard/file/103/icon-6566.ico +0 -0
- data/mod/05_standard/file/103/large-6566.ico +0 -0
- data/mod/05_standard/file/103/medium-6566.ico +0 -0
- data/mod/05_standard/file/103/original-6566.ico +0 -0
- data/mod/05_standard/file/103/small-6566.ico +0 -0
- data/mod/05_standard/file/79/icon-6556.png +0 -0
- data/mod/05_standard/file/79/large-6556.png +0 -0
- data/mod/05_standard/file/79/medium-6556.png +0 -0
- data/mod/05_standard/file/79/original-6556.png +0 -0
- data/mod/05_standard/file/79/small-6556.png +0 -0
- data/mod/05_standard/file/790/icon-6419.png +0 -0
- data/mod/05_standard/file/790/large-6419.png +0 -0
- data/mod/05_standard/file/790/medium-6419.png +0 -0
- data/mod/05_standard/file/790/original-6419.png +0 -0
- data/mod/05_standard/file/790/small-6419.png +0 -0
- data/mod/05_standard/set/all/account.rb +67 -0
- data/mod/05_standard/set/all/attach.rb +152 -0
- data/mod/05_standard/set/all/comment.rb +39 -0
- data/mod/05_standard/set/all/error.rb +214 -0
- data/mod/05_standard/set/all/event_viz.rb +62 -0
- data/mod/05_standard/set/all/links.rb +110 -0
- data/mod/05_standard/set/all/rich_html/content.rb +173 -0
- data/mod/05_standard/set/all/rich_html/editing.rb +145 -0
- data/mod/05_standard/set/all/rich_html/form.rb +234 -0
- data/mod/05_standard/set/all/rich_html/header.rb +64 -0
- data/mod/05_standard/set/all/rich_html/wrapper.rb +105 -0
- data/mod/05_standard/set/right/account.rb +180 -0
- data/mod/05_standard/set/right/email.rb +52 -0
- data/mod/05_standard/set/right/password.rb +39 -0
- data/mod/05_standard/set/right/salt.rb +5 -0
- data/mod/05_standard/set/right/stats.rb +35 -0
- data/mod/05_standard/set/right/status.rb +9 -0
- data/mod/05_standard/set/right/token.rb +5 -0
- data/mod/05_standard/set/right/when_created.rb +5 -0
- data/mod/05_standard/set/right/when_last_edited.rb +5 -0
- data/mod/05_standard/set/rstar/rules.rb +407 -0
- data/mod/05_standard/set/self/account_links.rb +61 -0
- data/mod/05_standard/set/self/alerts.rb +5 -0
- data/mod/05_standard/set/self/all.rb +21 -0
- data/mod/05_standard/set/self/foot.rb +8 -0
- data/mod/05_standard/set/self/head.rb +121 -0
- data/mod/05_standard/set/self/navbox.rb +20 -0
- data/mod/05_standard/set/self/now.rb +6 -0
- data/mod/05_standard/set/self/recent.rb +48 -0
- data/mod/05_standard/set/self/search.rb +43 -0
- data/mod/05_standard/set/self/signin.rb +121 -0
- data/mod/05_standard/set/self/stats.rb +91 -0
- data/mod/05_standard/set/self/version.rb +9 -0
- data/mod/05_standard/set/type/basic.rb +46 -0
- data/mod/05_standard/set/type/cardtype.rb +43 -0
- data/mod/05_standard/set/type/date.rb +8 -0
- data/mod/05_standard/set/type/file.rb +85 -0
- data/mod/05_standard/set/type/html.rb +22 -0
- data/mod/05_standard/set/type/image.rb +67 -0
- data/mod/05_standard/set/type/layout_type.rb +14 -0
- data/mod/05_standard/set/type/number.rb +19 -0
- data/mod/05_standard/set/type/phrase.rb +3 -0
- data/mod/05_standard/set/type/search_type.rb +243 -0
- data/mod/05_standard/set/type/set.rb +198 -0
- data/mod/05_standard/set/type/signup.rb +144 -0
- data/mod/05_standard/set/type/toggle.rb +12 -0
- data/mod/05_standard/set/type/uri.rb +11 -0
- data/mod/05_standard/set/type/user.rb +72 -0
- data/mod/05_standard/spec/chunk/include_spec.rb +186 -0
- data/mod/05_standard/spec/chunk/link_spec.rb +61 -0
- data/mod/05_standard/spec/format/css_format_spec.rb +5 -0
- data/mod/05_standard/spec/format/csv_format_spec.rb +5 -0
- data/mod/05_standard/spec/format/email_html_format_spec.rb +5 -0
- data/mod/05_standard/spec/format/file_format_spec.rb +5 -0
- data/mod/05_standard/spec/format/js_format_spec.rb +5 -0
- data/mod/05_standard/spec/format/json_format_spec.rb +5 -0
- data/mod/05_standard/spec/format/rss_format_spec.rb +5 -0
- data/mod/05_standard/spec/format/xml_format_spec.rb +5 -0
- data/mod/05_standard/spec/set/all/account_spec.rb +137 -0
- data/mod/05_standard/spec/set/all/attach_spec.rb +9 -0
- data/mod/05_standard/spec/set/all/comment_spec.rb +5 -0
- data/mod/05_standard/spec/set/all/email_html_spec.rb +15 -0
- data/mod/05_standard/spec/set/all/error_spec.rb +9 -0
- data/mod/05_standard/spec/set/all/event_viz_spec.rb +9 -0
- data/mod/05_standard/spec/set/all/history_spec.rb +173 -0
- data/mod/05_standard/spec/set/all/rich_html/form_spec.rb +43 -0
- data/mod/05_standard/spec/set/all/rich_html/wrapper_spec.rb +28 -0
- data/mod/05_standard/spec/set/right/account_spec.rb +162 -0
- data/mod/05_standard/spec/set/right/email_spec.rb +55 -0
- data/mod/05_standard/spec/set/right/password_spec.rb +45 -0
- data/mod/05_standard/spec/set/right/salt_spec.rb +5 -0
- data/mod/05_standard/spec/set/right/stats_spec.rb +13 -0
- data/mod/05_standard/spec/set/right/status_spec.rb +5 -0
- data/mod/05_standard/spec/set/right/token_spec.rb +5 -0
- data/mod/05_standard/spec/set/right/when_created_spec.rb +7 -0
- data/mod/05_standard/spec/set/right/when_last_edited_spec.rb +7 -0
- data/mod/05_standard/spec/set/rstar/rules_spec.rb +25 -0
- data/mod/05_standard/spec/set/self/account_links_spec.rb +9 -0
- data/mod/05_standard/spec/set/self/alerts_spec.rb +5 -0
- data/mod/05_standard/spec/set/self/all_spec.rb +48 -0
- data/mod/05_standard/spec/set/self/foot_spec.rb +5 -0
- data/mod/05_standard/spec/set/self/head_spec.rb +17 -0
- data/mod/05_standard/spec/set/self/navbox_spec.rb +7 -0
- data/mod/05_standard/spec/set/self/now_spec.rb +7 -0
- data/mod/05_standard/spec/set/self/recent_spec.rb +5 -0
- data/mod/05_standard/spec/set/self/search_spec.rb +5 -0
- data/mod/05_standard/spec/set/self/signin_spec.rb +73 -0
- data/mod/05_standard/spec/set/self/stats_spec.rb +12 -0
- data/mod/05_standard/spec/set/self/version_spec.rb +7 -0
- data/mod/05_standard/spec/set/type/basic_spec.rb +5 -0
- data/mod/05_standard/spec/set/type/cardtype_spec.rb +5 -0
- data/mod/05_standard/spec/set/type/date_spec.rb +7 -0
- data/mod/05_standard/spec/set/type/email_template_spec.rb +208 -0
- data/mod/05_standard/spec/set/type/file_spec.rb +5 -0
- data/mod/05_standard/spec/set/type/html_spec.rb +23 -0
- data/mod/05_standard/spec/set/type/image_spec.rb +16 -0
- data/mod/05_standard/spec/set/type/layout_type_spec.rb +7 -0
- data/mod/05_standard/spec/set/type/number_spec.rb +7 -0
- data/mod/05_standard/spec/set/type/phrase_spec.rb +7 -0
- data/mod/05_standard/spec/set/type/search_type_spec.rb +27 -0
- data/mod/05_standard/spec/set/type/set_spec.rb +26 -0
- data/mod/05_standard/spec/set/type/signup_spec.rb +228 -0
- data/mod/05_standard/spec/set/type/toggle_spec.rb +12 -0
- data/mod/05_standard/spec/set/type/uri_spec.rb +41 -0
- data/mod/05_standard/spec/set/type/user_spec.rb +5 -0
- data/mod/06_bootstrap/lib/javascript/bootstrap.js +2306 -0
- data/mod/06_bootstrap/lib/javascript/bootstrap.min.js +7 -0
- data/mod/06_bootstrap/lib/stylesheets/bootstrap-theme.css +476 -0
- data/mod/06_bootstrap/lib/stylesheets/bootstrap.css +6565 -0
- data/mod/06_bootstrap/lib/stylesheets/darkly.css +6583 -0
- data/mod/06_bootstrap/set/all/bootstrap/form.rb +37 -0
- data/mod/06_bootstrap/set/all/bootstrap/header.rb +29 -0
- data/mod/06_bootstrap/set/all/bootstrap/wrapper.rb +12 -0
- data/mod/06_bootstrap/set/all/rich_bootstrap.rb +28 -0
- data/mod/06_bootstrap/set/self/bootstrap_css.rb +7 -0
- data/mod/06_bootstrap/set/self/bootstrap_js.rb +7 -0
- data/mod/06_bootstrap/set/self/bootstrap_theme_css.rb +7 -0
- data/mod/06_bootstrap/set/self/navbox.rb +32 -0
- data/mod/06_bootstrap/set/type/search_type.rb +79 -0
- data/mod/06_bootstrap/spec/set/all/bootstrap/form_spec.rb +13 -0
- data/spec/lib/card/action_spec.rb +14 -0
- data/spec/lib/card/auth_spec.rb +17 -0
- data/spec/lib/card/cache_spec.rb +122 -0
- data/spec/lib/card/chunk_spec.rb +17 -0
- data/spec/lib/card/codename_spec.rb +25 -0
- data/spec/lib/card/content_spec.rb +314 -0
- data/spec/lib/card/diff_spec.rb +210 -0
- data/spec/lib/card/format_spec.rb +82 -0
- data/spec/lib/card/loader_spec.rb +39 -0
- data/spec/lib/card/log_spec.rb +270 -0
- data/spec/lib/card/name_spec.rb +279 -0
- data/spec/lib/card/query_spec.rb +456 -0
- data/spec/lib/card/reference_spec.rb +213 -0
- data/spec/lib/card/set_pattern_spec.rb +56 -0
- data/spec/lib/card/set_spec.rb +88 -0
- data/spec/mailers/mailer_spec.rb +64 -0
- data/spec/models/card/cardtype_spec.rb +216 -0
- data/spec/models/card/create_spec.rb +82 -0
- data/spec/models/card/trash_spec.rb +260 -0
- data/spec/models/card/type_transition_spec.rb +161 -0
- data/spec/models/card/validation_spec.rb +36 -0
- data/spec/models/card_spec.rb +177 -0
- data/spec/spec_helper.rb +130 -0
- data/test/fixtures/.gitkeep +0 -0
- data/test/fixtures/card_actions.yml +5706 -0
- data/test/fixtures/card_acts.yml +835 -0
- data/test/fixtures/card_changes.yml +17182 -0
- data/test/fixtures/card_references.yml +5405 -0
- data/test/fixtures/cards.yml +15533 -0
- data/test/fixtures/mao2.jpg +0 -0
- data/test/fixtures/rails.gif +0 -0
- data/test/seed.rb +201 -0
- metadata +762 -38
- data/.gitignore +0 -17
- data/Gemfile +0 -4
- data/LICENSE.txt +0 -22
- data/README.md +0 -29
- data/Rakefile +0 -1
@@ -0,0 +1,58 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
2
|
+
|
3
|
+
describe Card::Set::All::Initialize do
|
4
|
+
describe "new" do
|
5
|
+
it "handles explicit nil as parameters" do
|
6
|
+
c = Card.new nil
|
7
|
+
expect(c).to be_instance_of(Card)
|
8
|
+
expect(c.name).to eq('')
|
9
|
+
end
|
10
|
+
|
11
|
+
it "handles nil name" do
|
12
|
+
c = Card.new :name => nil
|
13
|
+
expect(c).to be_instance_of(Card)
|
14
|
+
expect(c.name).to eq('')
|
15
|
+
end
|
16
|
+
|
17
|
+
it 'handles legit name' do
|
18
|
+
c = Card.new :name => 'Ceee'
|
19
|
+
expect(c).to be_instance_of(Card)
|
20
|
+
expect(c.name).to eq('Ceee')
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
|
25
|
+
describe "module inclusion" do
|
26
|
+
context '(search)' do
|
27
|
+
before do
|
28
|
+
@c = Card.new :type=>'Search', :name=>'Module Inclusion Test Card'
|
29
|
+
end
|
30
|
+
|
31
|
+
it "happens after new" do
|
32
|
+
expect(@c.respond_to?( :get_query )).to be_truthy
|
33
|
+
end
|
34
|
+
|
35
|
+
it "happens after save" do
|
36
|
+
expect(@c.respond_to?( :get_query )).to be_truthy
|
37
|
+
@c.save!
|
38
|
+
expect(@c.respond_to?( :get_query )).to be_truthy
|
39
|
+
end
|
40
|
+
|
41
|
+
it "happens after fetch" do
|
42
|
+
@c.save!
|
43
|
+
c = Card.fetch(@c.name)
|
44
|
+
expect(c.respond_to?( :get_query )).to be_truthy
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
context '(pointer)' do
|
49
|
+
it "happens with explicit pointer setting" do
|
50
|
+
expect(Card.new(:type=>'Pointer').respond_to?(:add_item)).to be_truthy
|
51
|
+
end
|
52
|
+
|
53
|
+
it "happens with implicit pointer setting (from template)" do
|
54
|
+
expect(Card.new(:name=>'Home+*cc').respond_to?(:add_item)).to be_truthy
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
@@ -0,0 +1,61 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
2
|
+
|
3
|
+
describe Card::Set::All::Name do
|
4
|
+
describe 'autoname' do
|
5
|
+
before do
|
6
|
+
Card::Auth.as_bot do
|
7
|
+
@b1 = Card.create! :name=>'Book+*type+*autoname', :content=>'b1'
|
8
|
+
end
|
9
|
+
end
|
10
|
+
|
11
|
+
it "should handle cards without names" do
|
12
|
+
c = Card.create! :type=>'Book'
|
13
|
+
expect(c.name).to eq('b1')
|
14
|
+
end
|
15
|
+
|
16
|
+
it "should increment again if name already exists" do
|
17
|
+
b1 = Card.create! :type=>'Book'
|
18
|
+
b2 = Card.create! :type=>'Book'
|
19
|
+
expect(b2.name).to eq('b2')
|
20
|
+
end
|
21
|
+
|
22
|
+
it "should handle trashed names" do
|
23
|
+
b1 = Card.create! :type=>'Book'
|
24
|
+
Card::Auth.as_bot { b1.delete }
|
25
|
+
b1 = Card.create! :type=>'Book'
|
26
|
+
expect(b1.name).to eq('b1')
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
describe 'codename' do
|
31
|
+
before :each do
|
32
|
+
@card = Card['a']
|
33
|
+
end
|
34
|
+
|
35
|
+
it 'should require admin permission' do
|
36
|
+
@card.update_attributes :codename=>'structure'
|
37
|
+
expect(@card.errors[:codename].first).to match(/only admins/)
|
38
|
+
end
|
39
|
+
|
40
|
+
it 'should check uniqueness' do
|
41
|
+
Card::Auth.as_bot do
|
42
|
+
@card.update_attributes :codename=>'structure'
|
43
|
+
expect(@card.errors[:codename].first).to match(/already in use/)
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
end
|
48
|
+
|
49
|
+
describe 'repair_key' do
|
50
|
+
it 'should fix broken keys' do
|
51
|
+
a = Card['a']
|
52
|
+
a.update_column 'key', 'broken_a'
|
53
|
+
a.expire
|
54
|
+
|
55
|
+
a = Card.find a.id
|
56
|
+
expect(a.key).to eq('broken_a')
|
57
|
+
a.repair_key
|
58
|
+
expect(a.key).to eq('a')
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
@@ -0,0 +1,81 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
2
|
+
|
3
|
+
describe Card::Set::All::Pattern do
|
4
|
+
|
5
|
+
describe :set_names do
|
6
|
+
it "returns self, type, all for simple cards" do
|
7
|
+
Card::Auth.as_bot do
|
8
|
+
card = Card.new( :name => "AnewCard" )
|
9
|
+
expect(card.set_names).to eq([ "Basic+*type","*all"])
|
10
|
+
card.save!
|
11
|
+
card = Card.fetch("AnewCard")
|
12
|
+
expect(card.set_names).to eq([ "AnewCard+*self","Basic+*type","*all"])
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
it "returns set names for simple star cards" do
|
17
|
+
Card::Auth.as_bot do
|
18
|
+
expect(Card.fetch('*update').set_names).to eq([
|
19
|
+
"*update+*self","*star","Setting+*type","*all"
|
20
|
+
])
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
it "returns set names for junction cards" do
|
25
|
+
Card::Auth.as_bot do
|
26
|
+
expect(Card.new( :name=>"Iliad+author" ).set_names).to eq([
|
27
|
+
"Book+author+*type plus right","author+*right","Basic+*type","*all plus","*all"
|
28
|
+
])
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
it "returns set names for compound star cards" do
|
33
|
+
Card::Auth.as_bot do
|
34
|
+
expect(Card.new( :name=>"Iliad+*to" ).set_names).to eq([
|
35
|
+
"Book+*to+*type plus right","*to+*right","*rstar","Pointer+*type","*all plus","*all"
|
36
|
+
])
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
it "handles type plus right prototypes properly" do #right place for this? really need more prototype tests...
|
41
|
+
Card::Auth.as_bot do
|
42
|
+
expect(Card.fetch('Fruit+flavor+*type plus right').prototype.set_names.include?('Fruit+flavor+*type plus right')).to be_truthy
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
|
48
|
+
describe :rule_set_keys do
|
49
|
+
it "returns correct set names for new cards" do
|
50
|
+
card = Card.new :name => "AnewCard"
|
51
|
+
expect(card.rule_set_keys).to eq([ "#{Card::BasicID}+type", "all"])
|
52
|
+
end
|
53
|
+
|
54
|
+
end
|
55
|
+
|
56
|
+
describe :safe_set_keys do
|
57
|
+
it "returns css names for simple star cards" do
|
58
|
+
Card::Auth.as_bot do
|
59
|
+
card = Card.new( :name => "*AnewCard")
|
60
|
+
expect(card.safe_set_keys).to eq("ALL TYPE-basic STAR")
|
61
|
+
card.save!
|
62
|
+
card = Card.fetch("*AnewCard")
|
63
|
+
expect(card.safe_set_keys).to eq("ALL TYPE-basic STAR SELF-Xanew_card")
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
it "returns set names for junction cards" do
|
68
|
+
card=Card.new( :name=>"Iliad+author" )
|
69
|
+
expect(card.safe_set_keys).to eq("ALL ALL_PLUS TYPE-basic RIGHT-author TYPE_PLUS_RIGHT-book-author")
|
70
|
+
card.save!
|
71
|
+
card = Card.fetch("Iliad+author")
|
72
|
+
expect(card.safe_set_keys).to eq("ALL ALL_PLUS TYPE-basic RIGHT-author TYPE_PLUS_RIGHT-book-author SELF-iliad-author")
|
73
|
+
end
|
74
|
+
end
|
75
|
+
|
76
|
+
describe :label do
|
77
|
+
it "returns label for name" do
|
78
|
+
expect(Card.new(:name=>'address+*right').label).to eq(%{All "+address" cards})
|
79
|
+
end
|
80
|
+
end
|
81
|
+
end
|
@@ -0,0 +1,505 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
2
|
+
|
3
|
+
class ::Card
|
4
|
+
def writeable_by(user)
|
5
|
+
Card::Auth.as(user.id) do
|
6
|
+
#warn "writeable #{Card::Auth.as_id}, #{user.inspect}"
|
7
|
+
ok? :update
|
8
|
+
end
|
9
|
+
end
|
10
|
+
|
11
|
+
def readable_by(user)
|
12
|
+
Card::Auth.as(user.id) do
|
13
|
+
ok? :read
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
|
19
|
+
module PermissionSpecHelper
|
20
|
+
|
21
|
+
def assert_hidden_from( user, card, msg='')
|
22
|
+
Card::Auth.as(user.id) { assert_hidden( card, msg ) }
|
23
|
+
end
|
24
|
+
|
25
|
+
def assert_not_hidden_from( user, card, msg='')
|
26
|
+
Card::Auth.as(user.id) { assert_not_hidden( card, msg ) }
|
27
|
+
end
|
28
|
+
|
29
|
+
def assert_locked_from( user, card, msg='')
|
30
|
+
Card::Auth.as(user.id) { assert_locked( card, msg ) }
|
31
|
+
end
|
32
|
+
|
33
|
+
def assert_not_locked_from( user, card, msg='')
|
34
|
+
Card::Auth.as(user.id) { assert_not_locked( card, msg ) }
|
35
|
+
end
|
36
|
+
|
37
|
+
def assert_hidden( card, msg='' )
|
38
|
+
assert !card.ok?(:read)
|
39
|
+
assert_equal [], Card.search(:id=>card.id).map(&:name), msg
|
40
|
+
end
|
41
|
+
|
42
|
+
def assert_not_hidden( card, msg='' )
|
43
|
+
assert card.ok?(:read)
|
44
|
+
assert_equal [card.name], Card.search(:id=>card.id).map(&:name), msg
|
45
|
+
end
|
46
|
+
|
47
|
+
def assert_locked( card, msg='' )
|
48
|
+
assert_equal false, card.ok?(:update), msg
|
49
|
+
end
|
50
|
+
|
51
|
+
def assert_not_locked( card, msg='' )
|
52
|
+
assert_equal true, card.ok?(:update), msg
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
include PermissionSpecHelper
|
57
|
+
|
58
|
+
describe Card::Set::All::Permissions do
|
59
|
+
|
60
|
+
#FIXME - lots of good tests here, but generally disorganized.
|
61
|
+
|
62
|
+
describe "reader rules" do
|
63
|
+
before do
|
64
|
+
@perm_card = Card.new(:name=>'Home+*self+*read', :type=>'Pointer', :content=>'[[Anyone Signed In]]')
|
65
|
+
end
|
66
|
+
|
67
|
+
it "should be *all+*read by default" do
|
68
|
+
card = Card.fetch('Home')
|
69
|
+
expect(card.read_rule_id).to eq(Card.fetch('*all+*read').id)
|
70
|
+
expect(card.who_can(:read)).to eq([Card::AnyoneID])
|
71
|
+
Card::Auth.as(:anonymous){ expect(card.ok?(:read)).to be_truthy }
|
72
|
+
end
|
73
|
+
|
74
|
+
it "should update to role ('Anyone Signed In')" do
|
75
|
+
|
76
|
+
name = @perm_card.name
|
77
|
+
Card::Auth.as_bot { @perm_card.save! }
|
78
|
+
pc = Card[name]
|
79
|
+
card = Card['Home']
|
80
|
+
#warn "card #{name}, #{card.inspect}, #{pc.inspect}"
|
81
|
+
expect(pc).to be
|
82
|
+
expect(card.read_rule_id).to eq(pc.id)
|
83
|
+
expect(card.who_can(:read)).to eq([Card::AnyoneSignedInID])
|
84
|
+
Card::Auth.as(:anonymous){ expect(card.ok?(:read)).to be_falsey }
|
85
|
+
end
|
86
|
+
|
87
|
+
it "should update to user ('Joe Admin')" do
|
88
|
+
@perm_card.content = '[[Joe Admin]]'
|
89
|
+
Card::Auth.as_bot { @perm_card.save! }
|
90
|
+
|
91
|
+
card = Card.fetch('Home')
|
92
|
+
expect(card.read_rule_id).to eq(@perm_card.id)
|
93
|
+
expect(card.who_can(:read)).to eq([Card['joe_admin'].id])
|
94
|
+
Card::Auth.as(:anonymous) { expect(card.ok?(:read)).to be_falsey }
|
95
|
+
Card::Auth.as(:joe_user) { expect(card.ok?(:read)).to be_falsey }
|
96
|
+
Card::Auth.as(:joe_admin) { expect(card.ok?(:read)).to be_truthy }
|
97
|
+
Card::Auth.as_bot { expect(card.ok?(:read)).to be_truthy }
|
98
|
+
end
|
99
|
+
|
100
|
+
it "should revert to more general rule when more specific (self) rule is deleted" do
|
101
|
+
Card::Auth.as_bot do
|
102
|
+
@perm_card.save!
|
103
|
+
@perm_card.delete!
|
104
|
+
end
|
105
|
+
card = Card.fetch('Home')
|
106
|
+
expect(card.read_rule_id).to eq(Card.fetch('*all+*read').id)
|
107
|
+
end
|
108
|
+
|
109
|
+
it "should revert to more general rule when more specific (right) rule is deleted" do
|
110
|
+
pc = nil
|
111
|
+
Card::Auth.as_bot do
|
112
|
+
pc=Card.create(:name=>'B+*right+*read', :type=>'Pointer', :content=>'[[Anyone Signed In]]')
|
113
|
+
end
|
114
|
+
expect(pc).to be
|
115
|
+
card = Card.fetch('A+B')
|
116
|
+
expect(card.read_rule_id).to eq(pc.id)
|
117
|
+
pc = Card.fetch(pc.name) #important to re-fetch to catch issues with detecting change in trash status.
|
118
|
+
Card::Auth.as_bot { pc.delete }
|
119
|
+
card = Card.fetch('A+B')
|
120
|
+
expect(card.read_rule_id).to eq(Card.fetch('*all+*read').id)
|
121
|
+
end
|
122
|
+
|
123
|
+
it "should revert to more general rule when more specific rule is renamed" do
|
124
|
+
|
125
|
+
Card::Auth.as_bot do
|
126
|
+
@perm_card.save!
|
127
|
+
@perm_card = Card[@perm_card.name]
|
128
|
+
@perm_card.name = 'Something else+*self+*read'
|
129
|
+
@perm_card.save!
|
130
|
+
end
|
131
|
+
|
132
|
+
card = Card.fetch('Home')
|
133
|
+
expect(card.read_rule_id).to eq(Card.fetch('*all+*read').id)
|
134
|
+
end
|
135
|
+
|
136
|
+
it "should not be overruled by a more general rule added later" do
|
137
|
+
Card::Auth.as_bot do
|
138
|
+
@perm_card.save!
|
139
|
+
c= Card.fetch('Home')
|
140
|
+
c.type_id = Card::PhraseID
|
141
|
+
c.save!
|
142
|
+
Card.create(:name=>'Phrase+*type+*read', :type=>'Pointer', :content=>'[[Joe User]]')
|
143
|
+
end
|
144
|
+
|
145
|
+
card = Card.fetch('Home')
|
146
|
+
expect(card.read_rule_id).to eq(@perm_card.id)
|
147
|
+
end
|
148
|
+
|
149
|
+
it "should get updated when trunk type change makes type-plus-right apply / unapply" do
|
150
|
+
@perm_card.name = "Phrase+B+*type plus right+*read"
|
151
|
+
Card::Auth.as_bot { @perm_card.save! }
|
152
|
+
expect(Card.fetch('A+B').read_rule_id).to eq(Card.fetch('*all+*read').id)
|
153
|
+
c = Card.fetch('A')
|
154
|
+
c.type_id = Card::PhraseID
|
155
|
+
c.save!
|
156
|
+
expect(Card.fetch('A+B').read_rule_id).to eq(@perm_card.id)
|
157
|
+
end
|
158
|
+
|
159
|
+
it "should work with relative settings" do
|
160
|
+
Card::Auth.as_bot do
|
161
|
+
@perm_card.save!
|
162
|
+
all_plus = Card.fetch '*all plus+*read', :new=>{:content=>'_left'}
|
163
|
+
all_plus.save
|
164
|
+
end
|
165
|
+
c = Card.new(:name=>'Home+Heart')
|
166
|
+
expect(c.who_can(:read)).to eq([Card::AnyoneSignedInID])
|
167
|
+
expect(c.permission_rule_card(:read).first.id).to eq(@perm_card.id)
|
168
|
+
c.save
|
169
|
+
expect(c.read_rule_id).to eq(@perm_card.id)
|
170
|
+
end
|
171
|
+
|
172
|
+
it "should get updated when relative settings change" do
|
173
|
+
Card::Auth.as_bot do
|
174
|
+
all_plus = Card.fetch '*all plus+*read', :new=>{:content=>'_left'}
|
175
|
+
all_plus.save
|
176
|
+
end
|
177
|
+
c = Card.new(:name=>'Home+Heart')
|
178
|
+
expect(c.who_can(:read)).to eq([Card::AnyoneID])
|
179
|
+
expect(c.permission_rule_card(:read).first.id).to eq(Card.fetch('*all+*read').id)
|
180
|
+
c.save
|
181
|
+
expect(c.read_rule_id).to eq(Card.fetch('*all+*read').id)
|
182
|
+
Card::Auth.as_bot { @perm_card.save! }
|
183
|
+
c2 = Card.fetch('Home+Heart')
|
184
|
+
expect(c2.who_can(:read)).to eq([Card::AnyoneSignedInID])
|
185
|
+
expect(c2.read_rule_id).to eq(@perm_card.id)
|
186
|
+
expect(Card.fetch('Home+Heart').read_rule_id).to eq(@perm_card.id)
|
187
|
+
Card::Auth.as_bot{ @perm_card.delete }
|
188
|
+
expect(Card.fetch('Home').read_rule_id).to eq(Card.fetch('*all+*read').id)
|
189
|
+
expect(Card.fetch('Home+Heart').read_rule_id).to eq(Card.fetch('*all+*read').id)
|
190
|
+
end
|
191
|
+
|
192
|
+
it "should insure that class overrides work with relative settings" do
|
193
|
+
Card::Auth.as_bot do
|
194
|
+
all_plus = Card.fetch '*all plus+*read', :new => { :content=>'_left' }
|
195
|
+
all_plus.save
|
196
|
+
Card::Auth.as_bot { @perm_card.save! }
|
197
|
+
c = Card.create(:name=>'Home+Heart')
|
198
|
+
expect(c.read_rule_id).to eq(@perm_card.id)
|
199
|
+
r = Card.create(:name=>'Heart+*right+*read', :type=>'Pointer', :content=>'[[Administrator]]')
|
200
|
+
expect(Card.fetch('Home+Heart').read_rule_id).to eq(r.id)
|
201
|
+
end
|
202
|
+
end
|
203
|
+
|
204
|
+
it "should work on virtual+virtual cards" do
|
205
|
+
c = Card.fetch('Number+*type+by name')
|
206
|
+
expect(c.ok?(:read)).to be_truthy
|
207
|
+
end
|
208
|
+
|
209
|
+
end
|
210
|
+
|
211
|
+
|
212
|
+
|
213
|
+
context '??' do
|
214
|
+
before do
|
215
|
+
Card::Auth.as_bot do
|
216
|
+
# Card::Auth.cache.reset
|
217
|
+
@u1, @u2, @u3, @r1, @r2, @r3, @c1, @c2, @c3 =
|
218
|
+
%w( u1 u2 u3 r1 r2 r3 c1 c2 c3 ).map do |x| Card[x] end
|
219
|
+
end
|
220
|
+
end
|
221
|
+
|
222
|
+
|
223
|
+
it "checking ok read should not add to errors" do
|
224
|
+
Card::Auth.as_bot do
|
225
|
+
expect(Card::Auth.always_ok?).to eq(true)
|
226
|
+
end
|
227
|
+
Card::Auth.as(:joe_user) do
|
228
|
+
expect(Card::Auth.always_ok?).to eq(false)
|
229
|
+
end
|
230
|
+
Card::Auth.as(:joe_admin) do
|
231
|
+
expect(Card::Auth.always_ok?).to eq(true)
|
232
|
+
Card.create! :name=>"Hidden"
|
233
|
+
Card.create(:name=>'Hidden+*self+*read', :type=>'Pointer', :content=>'[[Anyone Signed In]]')
|
234
|
+
end
|
235
|
+
|
236
|
+
Card::Auth.as(:anonymous) do
|
237
|
+
h = Card.fetch('Hidden')
|
238
|
+
expect(h.ok?(:read)).to eq(false)
|
239
|
+
expect(h.errors.empty?).not_to eq(nil)
|
240
|
+
end
|
241
|
+
end
|
242
|
+
|
243
|
+
it "should be granted to admin if to anybody" do
|
244
|
+
Card::Auth.as_bot do
|
245
|
+
c1 = Card['c1']
|
246
|
+
Card.create! :name=>'c1+*self+*comment', :type=>'Pointer', :content=>'[[r1]]'
|
247
|
+
expect(c1.who_can( :comment )).to eq([Card['r1'].id])
|
248
|
+
expect(c1.ok?(:comment)).to be_truthy
|
249
|
+
end
|
250
|
+
end
|
251
|
+
|
252
|
+
it "reader setting" do
|
253
|
+
Card.where(:trash=>false).each do |c|
|
254
|
+
prc = c.permission_rule_card(:read)
|
255
|
+
#warn "C #{c.inspect}, #{c.read_rule_id}, #{prc.first.id}, #{c.read_rule_class}, #{prc.second}, #{prc.first.inspect}" unless prc.last == c.read_rule_class && prc.first.id == c.read_rule_id
|
256
|
+
expect(prc.last).to eq(c.read_rule_class)
|
257
|
+
expect(prc.first.id).to eq(c.read_rule_id)
|
258
|
+
end
|
259
|
+
end
|
260
|
+
|
261
|
+
|
262
|
+
it "write user permissions" do
|
263
|
+
Card::Auth.as_bot do
|
264
|
+
@u1.fetch(:trait=>:roles, :new=>{}).items = [@r1, @r2]
|
265
|
+
@u2.fetch(:trait=>:roles, :new=>{}).items = [@r1, @r3]
|
266
|
+
@u3.fetch(:trait=>:roles, :new=>{}).items = [@r1, @r2, @r3]
|
267
|
+
|
268
|
+
cards=[1,2,3].map do |num|
|
269
|
+
Card.create(:name=>"c#{num}+*self+*update", :type=>'Pointer', :content=>"[[u#{num}]]")
|
270
|
+
end
|
271
|
+
end
|
272
|
+
|
273
|
+
@c1 = Card['c1']
|
274
|
+
assert_not_locked_from( @u1, @c1 )
|
275
|
+
assert_locked_from( @u2, @c1 )
|
276
|
+
assert_locked_from( @u3, @c1 )
|
277
|
+
|
278
|
+
@c2 = Card['c2']
|
279
|
+
assert_locked_from( @u1, @c2 )
|
280
|
+
assert_not_locked_from( @u2, @c2 )
|
281
|
+
assert_locked_from( @u3, @c2 )
|
282
|
+
end
|
283
|
+
|
284
|
+
it "read group permissions" do
|
285
|
+
Card::Auth.as_bot do
|
286
|
+
@u1.fetch(:trait=>:roles).items = [@r1, @r2]
|
287
|
+
@u2.fetch(:trait=>:roles).items = [@r1, @r3]
|
288
|
+
|
289
|
+
[1,2,3].each do |num|
|
290
|
+
Card.create(:name=>"c#{num}+*self+*read", :type=>'Pointer', :content=>"[[r#{num}]]")
|
291
|
+
end
|
292
|
+
end
|
293
|
+
|
294
|
+
assert_not_hidden_from( @u1, @c1 )
|
295
|
+
assert_not_hidden_from( @u1, @c2 )
|
296
|
+
assert_hidden_from( @u1, @c3 )
|
297
|
+
|
298
|
+
assert_not_hidden_from( @u2, @c1 )
|
299
|
+
assert_hidden_from( @u2, @c2 )
|
300
|
+
assert_not_hidden_from( @u2, @c3 )
|
301
|
+
end
|
302
|
+
|
303
|
+
it "write group permissions" do
|
304
|
+
Card::Auth.as_bot do
|
305
|
+
[1,2,3].each do |num|
|
306
|
+
Card.create(:name=>"c#{num}+*self+*update", :type=>'Pointer', :content=>"[[r#{num}]]")
|
307
|
+
end
|
308
|
+
|
309
|
+
@u3.fetch(:trait=>:roles, :new=>{}).items = [@r1]
|
310
|
+
end
|
311
|
+
|
312
|
+
%{ u1 u2 u3
|
313
|
+
c1(r1) T T T
|
314
|
+
c2(r2) T T F
|
315
|
+
c3(r3) T F F
|
316
|
+
}
|
317
|
+
|
318
|
+
assert_equal true, @c1.writeable_by(@u1), "c1 writeable by u1"
|
319
|
+
assert_equal true, @c1.writeable_by(@u2), "c1 writeable by u2"
|
320
|
+
assert_equal true, @c1.writeable_by(@u3), "c1 writeable by u3"
|
321
|
+
assert_equal true, @c2.writeable_by(@u1), "c2 writeable by u1"
|
322
|
+
assert_equal true, @c2.writeable_by(@u2), "c2 writeable by u2"
|
323
|
+
assert_equal false, @c2.writeable_by(@u3), "c2 writeable by u3"
|
324
|
+
assert_equal true, @c3.writeable_by(@u1), "c3 writeable by u1"
|
325
|
+
assert_equal false, @c3.writeable_by(@u2), "c3 writeable by u2"
|
326
|
+
assert_equal false, @c3.writeable_by(@u3), "c3 writeable by u3"
|
327
|
+
end
|
328
|
+
|
329
|
+
it "read user permissions" do
|
330
|
+
Card::Auth.as_bot {
|
331
|
+
@u1.fetch(:trait=>:roles, :new=>{}).items = [@r1, @r2]
|
332
|
+
@u2.fetch(:trait=>:roles, :new=>{}).items = [@r1, @r3]
|
333
|
+
@u3.fetch(:trait=>:roles, :new=>{}).items = [@r1, @r2, @r3]
|
334
|
+
|
335
|
+
[1,2,3].each do |num|
|
336
|
+
Card.create(:name=>"c#{num}+*self+*read", :type=>'Pointer', :content=>"[[u#{num}]]")
|
337
|
+
end
|
338
|
+
}
|
339
|
+
|
340
|
+
|
341
|
+
# NOTE: retrieving private cards is known not to work now.
|
342
|
+
# assert_not_hidden_from( @u1, @c1 )
|
343
|
+
# assert_not_hidden_from( @u2, @c2 )
|
344
|
+
|
345
|
+
assert_hidden_from( @u2, @c1 )
|
346
|
+
assert_hidden_from( @u3, @c1 )
|
347
|
+
assert_hidden_from( @u1, @c2 )
|
348
|
+
assert_hidden_from( @u3, @c2 )
|
349
|
+
end
|
350
|
+
|
351
|
+
context "create permissions" do
|
352
|
+
before do
|
353
|
+
Card::Auth.as_bot do
|
354
|
+
Card.create! :name=>'*structure+*right+*create', :type=>'Pointer', :content=>'[[Anyone Signed In]]'
|
355
|
+
Card.create! :name=>'*self+*right+*create', :type=>'Pointer', :content=>'[[Anyone Signed In]]'
|
356
|
+
end
|
357
|
+
end
|
358
|
+
|
359
|
+
it "should inherit" do
|
360
|
+
Card::Auth.as(:anyone_signed_in) do
|
361
|
+
expect(Card.fetch( 'A+*self' ).ok?(:create)).to be_truthy #explicitly granted above
|
362
|
+
expect(Card.fetch( 'A+*right').ok?(:create)).to be_falsey #by default restricted
|
363
|
+
|
364
|
+
expect(Card.fetch( 'A+*self+*structure', :new=>{} ).ok?(:create)).to be_truthy # +*structure granted;
|
365
|
+
expect(Card.fetch( 'A+*right+*structure', :new=>{} ).ok?(:create)).to be_falsey # can't create A+B, therefore can't create A+B+C
|
366
|
+
end
|
367
|
+
end
|
368
|
+
|
369
|
+
end
|
370
|
+
|
371
|
+
|
372
|
+
it "private wql" do
|
373
|
+
# set up cards of type TestType, 2 with nil reader, 1 with role1 reader
|
374
|
+
Card::Auth.as_bot do
|
375
|
+
[@c1,@c2,@c3].each do |c|
|
376
|
+
c.update_attributes :content => 'WeirdWord'
|
377
|
+
end
|
378
|
+
Card.create(:name=>"c1+*self+*read", :type=>'Pointer', :content=>"[[u1]]")
|
379
|
+
end
|
380
|
+
|
381
|
+
Card::Auth.as(@u1) do
|
382
|
+
expect(Card.search(:content=>'WeirdWord').map(&:name).sort).to eq(%w( c1 c2 c3 ))
|
383
|
+
end
|
384
|
+
Card::Auth.as(@u2) do
|
385
|
+
expect(Card.search(:content=>'WeirdWord').map(&:name).sort).to eq(%w( c2 c3 ))
|
386
|
+
end
|
387
|
+
end
|
388
|
+
|
389
|
+
it "role wql" do
|
390
|
+
#warn "u1 roles #{Card[ @u1.id ].fetch(:trait=>:roles).item_names.inspect}"
|
391
|
+
|
392
|
+
# set up cards of type TestType, 2 with nil reader, 1 with role1 reader
|
393
|
+
Card::Auth.as_bot do
|
394
|
+
[@c1,@c2,@c3].each do |c|
|
395
|
+
c.update_attributes :content => 'WeirdWord'
|
396
|
+
end
|
397
|
+
Card.create(:name=>"c1+*self+*read", :type=>'Pointer', :content=>"[[r3]]")
|
398
|
+
end
|
399
|
+
|
400
|
+
Card::Auth.as(@u1) do
|
401
|
+
expect(Card.search(:content=>'WeirdWord').map(&:name).sort).to eq(%w( c1 c2 c3 ))
|
402
|
+
end
|
403
|
+
Card::Auth.current_id =nil # for Card::Auth.as to be effective, you can't have a logged in user
|
404
|
+
Card::Auth.as(@u2) do
|
405
|
+
expect(Card.search(:content=>'WeirdWord').map(&:name).sort).to eq(%w( c2 c3 ))
|
406
|
+
end
|
407
|
+
end
|
408
|
+
|
409
|
+
def permission_matrix
|
410
|
+
# TODO
|
411
|
+
# generate this graph three ways:
|
412
|
+
# given a card with editor in group X, can Y edit it?
|
413
|
+
# given a card with reader in group X, can Y view it?
|
414
|
+
# given c card with group anon, can Y change the reader/writer to X
|
415
|
+
|
416
|
+
# X,Y in Anon, auth Member, auth Nonmember, admin
|
417
|
+
|
418
|
+
%{
|
419
|
+
A V C J G
|
420
|
+
A * * * * *
|
421
|
+
V * * . * .
|
422
|
+
C * * * . .
|
423
|
+
J * * . . .
|
424
|
+
G * . . . .
|
425
|
+
}
|
426
|
+
|
427
|
+
end
|
428
|
+
|
429
|
+
end
|
430
|
+
|
431
|
+
|
432
|
+
|
433
|
+
|
434
|
+
it "should let joe view new cards" do
|
435
|
+
expect(Card.new.ok?(:read)).to be_truthy
|
436
|
+
end
|
437
|
+
|
438
|
+
|
439
|
+
context "default permissions" do
|
440
|
+
before do
|
441
|
+
@c = Card.create! :name=>"sky blue"
|
442
|
+
end
|
443
|
+
|
444
|
+
it "should let anonymous users view basic cards" do
|
445
|
+
Card::Auth.as :anonymous do
|
446
|
+
expect(@c.ok?(:read)).to be_truthy
|
447
|
+
end
|
448
|
+
end
|
449
|
+
|
450
|
+
it "should let joe user basic cards" do
|
451
|
+
Card::Auth.as :joe_user do
|
452
|
+
expect(@c.ok?(:read)).to be_truthy
|
453
|
+
end
|
454
|
+
end
|
455
|
+
end
|
456
|
+
|
457
|
+
it "should allow anyone signed in to create Basic Cards" do
|
458
|
+
expect(Card.new.ok?(:create)).to be_truthy
|
459
|
+
end
|
460
|
+
|
461
|
+
it "should not allow someone not signed in to create Basic Cards" do
|
462
|
+
Card::Auth.as :anonymous do
|
463
|
+
expect(Card.new.ok?(:create)).not_to be_truthy
|
464
|
+
end
|
465
|
+
end
|
466
|
+
|
467
|
+
|
468
|
+
|
469
|
+
context "settings based permissions" do
|
470
|
+
before do
|
471
|
+
Card::Auth.as_bot do
|
472
|
+
@delete_rule_card = Card.fetch '*all+*delete', :new=>{}
|
473
|
+
@delete_rule_card.type_id = Card::PointerID
|
474
|
+
@delete_rule_card.content = '[[Joe_User]]'
|
475
|
+
@delete_rule_card.save!
|
476
|
+
end
|
477
|
+
end
|
478
|
+
|
479
|
+
it "should handle delete as a setting" do
|
480
|
+
c = Card.new :name=>'whatever'
|
481
|
+
expect(c.who_can(:delete)).to eq([Card['joe_user'].id])
|
482
|
+
Card::Auth.as(:joe_user) do
|
483
|
+
expect(c.ok?(:delete)).to eq(true)
|
484
|
+
end
|
485
|
+
Card::Auth.as(:u1) do
|
486
|
+
expect(c.ok?(:delete)).to eq(false)
|
487
|
+
end
|
488
|
+
Card::Auth.as(:anonymous) do
|
489
|
+
expect(c.ok?(:delete)).to eq(false)
|
490
|
+
end
|
491
|
+
Card::Auth.as_bot do
|
492
|
+
expect(c.ok?(:delete)).to eq(true) #because administrator
|
493
|
+
end
|
494
|
+
end
|
495
|
+
end
|
496
|
+
|
497
|
+
|
498
|
+
|
499
|
+
end
|
500
|
+
|
501
|
+
|
502
|
+
# FIXME-perm
|
503
|
+
|
504
|
+
# need test for
|
505
|
+
# changing cardtypes gives you correct permissions (changing cardtype in general...)
|