wagn 1.13.0 → 1.14.0.pre1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Guardfile +3 -2
- data/VERSION +1 -1
- data/app/controllers/card_controller.rb +33 -38
- data/config/routes.rb +2 -2
- data/config/version.txt +1 -1
- data/db/bootstrap/card_actions.yml +3543 -0
- data/db/bootstrap/card_acts.yml +7 -0
- data/db/bootstrap/card_changes.yml +9150 -0
- data/db/bootstrap/card_references.yml +666 -344
- data/db/bootstrap/cards.yml +3256 -1702
- 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_cards/20130411191151_renaming_for_menu.rb +42 -45
- data/db/migrate_cards/20130411211600_delete_old_related_tab_cards.rb +13 -16
- data/db/migrate_cards/20130419215612_import_help_text.rb +7 -10
- data/db/migrate_cards/20130823192433_add_style_cards.rb +77 -81
- data/db/migrate_cards/20130910183318_move_styles_to_content.rb +4 -7
- data/db/migrate_cards/20130920214038_jsonize_tinymce.rb +9 -12
- data/db/migrate_cards/20130920291703_update_stylesheets.rb +10 -13
- data/db/migrate_cards/20130927191728_account_events.rb +15 -18
- data/db/migrate_cards/20131016172445_common_css_patch.rb +5 -8
- data/db/migrate_cards/20140110193325_reset_account_request_type.rb +4 -7
- data/db/migrate_cards/20140307231621_user_data_to_cards.rb +50 -53
- data/db/migrate_cards/20140317035504_account_requests_to_signups.rb +39 -42
- data/db/migrate_cards/20140512155840_add_script_cards.rb +56 -59
- data/db/migrate_cards/20140629222005_add_email_cards.rb +168 -0
- data/db/migrate_cards/20140725180118_config_card_updates.rb +4 -7
- data/db/migrate_cards/data/mailer/follower_notification_email.html +9 -0
- data/db/migrate_cards/data/mailer/follower_notification_email.txt +11 -0
- data/db/migrate_cards/data/mailer/mail_config.json +22 -0
- data/db/migrate_cards/data/mailer/password_reset_email.html +10 -0
- data/db/migrate_cards/data/mailer/password_reset_email.txt +11 -0
- data/db/migrate_cards/data/mailer/signup_alert_email.html +7 -0
- data/db/migrate_cards/data/mailer/signup_alert_email.txt +5 -0
- data/db/migrate_cards/data/mailer/verification_email.html +9 -0
- data/db/migrate_cards/data/mailer/verification_email.txt +8 -0
- data/db/schema.rb +31 -1
- data/features/conflict.feature +39 -0
- data/features/flexmail.feature +54 -54
- data/features/notifications.feature +4 -2
- data/features/reset_password.feature +1 -1
- data/features/step_definitions/wagn_steps.rb +20 -2
- data/features/step_definitions/window_steps.rb +23 -0
- data/features/support/env.rb +1 -0
- data/features/update_includers.feature +16 -10
- data/features/watch.feature +2 -2
- data/lib/card.rb +11 -10
- data/lib/card/act.rb +63 -0
- data/lib/card/action.rb +194 -0
- data/lib/card/change.rb +29 -0
- data/lib/card/content.rb +1 -1
- data/lib/card/diff.rb +229 -276
- data/lib/card/env.rb +4 -3
- data/lib/card/format.rb +2 -5
- data/lib/card/generators/card_migration/USAGE +15 -3
- data/lib/card/generators/card_migration/card_migration_generator.rb +22 -2
- data/lib/card/generators/card_migration/templates/card_migration.erb +4 -5
- data/lib/card/generators/format/USAGE +2 -2
- data/lib/card/generators/format/format_generator.rb +2 -2
- data/lib/card/generators/set/USAGE +2 -2
- data/lib/card/mailer.rb +21 -100
- data/lib/card/name.rb +4 -3
- data/lib/card/query.rb +2 -2
- data/lib/card/query/card_spec.rb +20 -30
- data/lib/card/query/value_spec.rb +2 -3
- data/lib/card/set.rb +3 -0
- data/lib/wagn/all.rb +6 -0
- data/lib/wagn/application.rb +16 -6
- data/lib/wagn/commands.rb +87 -27
- data/lib/wagn/config/environments/development.rb +17 -0
- data/lib/wagn/config/environments/test.rb +14 -1
- data/lib/wagn/config/initializers/airbrake.rb +1 -1
- data/lib/wagn/generators/wagn/templates/Gemfile +27 -9
- data/lib/wagn/generators/wagn/templates/config/application.rb +12 -3
- data/lib/wagn/generators/wagn/templates/simplecov +5 -0
- data/lib/wagn/generators/wagn/templates/spec/spec_helper.rb +1 -0
- data/lib/wagn/generators/wagn/wagn_generator.rb +75 -45
- data/lib/wagn/location.rb +9 -0
- data/lib/wagn/migration.rb +96 -0
- data/lib/wagn/mods_spec_helper.rb +16 -8
- data/lib/wagn/simplecov_helper.rb +61 -0
- data/lib/wagn/{wagn_spec_helper.rb → spec_helper.rb} +11 -3
- data/lib/wagn/tasks/test.rake +1 -1
- data/lib/wagn/tasks/wagn.rake +100 -34
- data/lib/wagn/version.rb +7 -2
- data/mod/{core → 01_core}/chunk/include.rb +0 -0
- data/mod/{core → 01_core}/chunk/link.rb +0 -0
- data/mod/{core → 01_core}/chunk/literal.rb +0 -0
- data/mod/{core → 01_core}/chunk/reference.rb +15 -3
- data/mod/{core → 01_core}/chunk/uri.rb +0 -0
- data/mod/{core → 01_core}/format/data_format.rb +0 -0
- data/mod/{core → 01_core}/format/html_format.rb +5 -2
- data/mod/{core → 01_core}/format/text_format.rb +0 -0
- data/mod/{core → 01_core}/layout/blank.html +0 -0
- data/mod/{core → 01_core}/layout/default.html +0 -0
- data/mod/{core → 01_core}/layout/noside.html +0 -0
- data/mod/{core → 01_core}/layout/pre.html +0 -0
- data/mod/{core → 01_core}/layout/simple.html +0 -0
- data/mod/{core → 01_core}/set/all/active_card.rb +0 -0
- data/mod/{core → 01_core}/set/all/collection.rb +33 -5
- data/mod/01_core/set/all/content.rb +144 -0
- data/mod/01_core/set/all/erb.rb +11 -0
- data/mod/{core → 01_core}/set/all/fetch.rb +8 -1
- data/mod/01_core/set/all/haml.rb +7 -0
- data/mod/{core → 01_core}/set/all/initialize.rb +4 -2
- data/mod/{core → 01_core}/set/all/name.rb +2 -3
- data/mod/01_core/set/all/notify.rb +215 -0
- data/mod/{core → 01_core}/set/all/pattern.rb +0 -0
- data/mod/{core → 01_core}/set/all/permissions.rb +1 -1
- data/mod/{core → 01_core}/set/all/phases.rb +24 -8
- data/mod/{core → 01_core}/set/all/references.rb +2 -2
- data/mod/{core → 01_core}/set/all/rules.rb +2 -2
- data/mod/{core → 01_core}/set/all/states.rb +1 -1
- data/mod/{core → 01_core}/set/all/templating.rb +4 -4
- data/mod/{core → 01_core}/set/all/tracked_attributes.rb +15 -64
- data/mod/{core → 01_core}/set/all/trash.rb +6 -5
- data/mod/{core → 01_core}/set/all/type.rb +0 -0
- data/mod/{core → 01_core}/set/all/utils.rb +1 -1
- data/mod/{core → 01_core}/set_pattern/01_all.rb +0 -0
- data/mod/{core → 01_core}/set_pattern/02_all_plus.rb +0 -0
- data/mod/{core → 01_core}/set_pattern/03_type.rb +0 -0
- data/mod/{core → 01_core}/set_pattern/04_star.rb +0 -0
- data/mod/{core → 01_core}/set_pattern/05_rstar.rb +0 -0
- data/mod/{core → 01_core}/set_pattern/06_right.rb +0 -0
- data/mod/{core → 01_core}/set_pattern/07_type_plus_right.rb +0 -0
- data/mod/{core → 01_core}/set_pattern/08_self.rb +0 -0
- data/mod/01_core/spec/chunk/literal_spec.rb +14 -0
- data/{spec/mod/core → mod/01_core/spec}/chunk/uri_spec.rb +3 -3
- data/{spec/mod/core → mod/01_core/spec}/format/data_format_spec.rb +0 -0
- data/{spec/mod/core → mod/01_core/spec}/format/html_format_spec.rb +9 -8
- data/{spec/mod/core → mod/01_core/spec}/format/text_format_spec.rb +0 -0
- data/{spec/mod/core → mod/01_core/spec}/set/all/active_card_spec.rb +0 -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/{spec/mod/core → mod/01_core/spec}/set/all/fetch_spec.rb +70 -68
- data/{spec/mod/core → mod/01_core/spec}/set/all/initialize_spec.rb +12 -12
- data/{spec/mod/core → mod/01_core/spec}/set/all/name_spec.rb +7 -7
- data/mod/01_core/spec/set/all/notify_spec.rb +199 -0
- data/{spec/mod/core → mod/01_core/spec}/set/all/pattern_spec.rb +16 -16
- data/{spec/mod/core → mod/01_core/spec}/set/all/permissions_spec.rb +62 -62
- data/{spec/mod/core → mod/01_core/spec}/set/all/phases_spec.rb +0 -0
- data/{spec/mod/core → mod/01_core/spec}/set/all/references_spec.rb +1 -1
- data/{spec/mod/core → mod/01_core/spec}/set/all/rules2_spec.rb +57 -57
- data/mod/01_core/spec/set/all/rules_spec.rb +81 -0
- data/{spec/mod/core → mod/01_core/spec}/set/all/states_spec.rb +0 -0
- data/{spec/mod/core → mod/01_core/spec}/set/all/templating_spec.rb +16 -12
- data/{spec/mod/core → mod/01_core/spec}/set/all/tracked_attributes_spec.rb +24 -22
- data/{spec/mod/core → mod/01_core/spec}/set/all/trash_spec.rb +2 -2
- data/{spec/mod/core → mod/01_core/spec}/set/all/type_spec.rb +13 -13
- data/{spec/mod/core → mod/01_core/spec}/set/all/utils_spec.rb +0 -0
- data/mod/{core → 02_basic_types}/set/type/plain_text.rb +0 -0
- data/mod/{standard → 02_basic_types}/set/type/pointer.rb +21 -8
- data/{spec/mod/standard/set/type → mod/02_basic_types/spec/set}/plain_text_spec.rb +0 -0
- data/{spec/mod/standard/set/type → mod/02_basic_types/spec/set}/pointer_spec.rb +22 -9
- data/mod/{standard → 03_machines}/lib/card/machine.rb +3 -2
- data/mod/{standard → 03_machines}/lib/card/machine_input.rb +1 -1
- data/mod/{standard → 03_machines}/lib/javascript/html5shiv-printshiv.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/jquery-ui.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/jquery.autosize.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/jquery.fileupload.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/jquery.iframe-transport.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/jquery.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/jquery.ui.autocomplete.html.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/jquery_ujs.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/jquerymobile.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/tinymce.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/wagn.js.coffee +17 -9
- data/mod/{standard → 03_machines}/lib/javascript/wagn_menu.js +0 -0
- data/mod/{standard → 03_machines}/lib/javascript/wagn_mod.js.coffee +1 -1
- data/mod/{standard → 03_machines}/lib/stylesheets/functional.scss +1 -1
- data/mod/{standard → 03_machines}/lib/stylesheets/jquery-ui-smoothness.css +0 -0
- data/mod/{standard → 03_machines}/lib/stylesheets/standard.scss +126 -21
- data/mod/{standard → 03_machines}/set/right/machine_output.rb +3 -2
- data/mod/{standard → 03_machines}/set/self/script_card_menu.rb +1 -1
- data/mod/{standard → 03_machines}/set/self/script_html5shiv_printshiv.rb +1 -1
- data/mod/{standard → 03_machines}/set/self/script_jquery.rb +1 -1
- data/mod/{standard → 03_machines}/set/self/script_jquery_helper.rb +1 -1
- data/mod/{standard → 03_machines}/set/self/script_slot.rb +1 -1
- data/mod/{standard → 03_machines}/set/self/script_tinymce.rb +1 -1
- data/mod/{standard → 03_machines}/set/self/style_functional.rb +1 -1
- data/mod/{standard → 03_machines}/set/self/style_jquery_ui_smoothness.rb +1 -1
- data/mod/{standard → 03_machines}/set/self/style_standard.rb +1 -1
- data/mod/{standard → 03_machines}/set/type/coffee_script.rb +0 -0
- data/mod/{standard → 03_machines}/set/type/css.rb +0 -0
- data/mod/{standard → 03_machines}/set/type/java_script.rb +0 -0
- data/mod/{standard → 03_machines}/set/type/scss.rb +0 -0
- data/mod/{standard → 03_machines}/set/type/skin.rb +0 -0
- data/{spec/mod/standard → mod/03_machines/spec}/lib/machine_input_spec.rb +0 -0
- data/{spec/mod/standard → mod/03_machines/spec}/lib/machine_spec.rb +4 -4
- data/{spec/mod/standard → mod/03_machines/spec}/set/right/machine_output_spec.rb +0 -0
- data/{spec/mod/standard → mod/03_machines/spec}/set/self/style_functional_spec.rb +0 -0
- data/{spec/mod/standard → mod/03_machines/spec}/set/self/style_jquery_ui_smoothness_spec.rb +0 -0
- data/{spec/mod/standard → mod/03_machines/spec}/set/self/style_standard_spec.rb +0 -0
- data/{spec/mod/standard → mod/03_machines/spec}/set/type/coffeescript_spec.rb +0 -0
- data/{spec/mod/standard → mod/03_machines/spec}/set/type/css_spec.rb +0 -0
- data/{spec/mod/standard → mod/03_machines/spec}/set/type/javascript_spec.rb +0 -0
- data/{spec/mod/standard → mod/03_machines/spec}/set/type/scss_spec.rb +1 -1
- data/{spec/mod/standard → mod/03_machines/spec}/set/type/skin_spec.rb +22 -0
- data/mod/04_settings/lib/card/setting.rb +57 -0
- data/mod/{core/set/right/structure.rb → 04_settings/set/right/add_help.rb} +0 -2
- data/mod/{standard → 04_settings}/set/right/comment.rb +0 -1
- data/mod/{standard → 04_settings}/set/right/create.rb +0 -1
- data/mod/04_settings/set/right/default.rb +3 -0
- data/mod/{standard → 04_settings}/set/right/delete.rb +2 -0
- data/mod/04_settings/set/right/help.rb +3 -0
- data/mod/{standard → 04_settings}/set/right/read.rb +0 -0
- data/mod/{standard → 04_settings}/set/right/script.rb +0 -0
- data/mod/04_settings/set/right/structure.rb +4 -0
- data/mod/{standard → 04_settings}/set/right/style.rb +0 -0
- data/mod/{standard → 04_settings}/set/right/update.rb +0 -0
- data/mod/04_settings/set/self/accountable.rb +2 -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/{standard → 04_settings}/set/type/setting.rb +8 -14
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/add_help_spec.rb +0 -0
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/comment_spec.rb +5 -5
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/create_spec.rb +0 -0
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/default_spec.rb +0 -0
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/delete_spec.rb +0 -0
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/help_spec.rb +0 -0
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/read_spec.rb +0 -0
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/script_spec.rb +0 -0
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/structure_spec.rb +4 -2
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/style_spec.rb +1 -1
- data/{spec/mod/standard → mod/04_settings/spec}/set/right/update_spec.rb +0 -0
- data/{spec/mod/standard → mod/04_settings/spec}/set/type/setting_spec.rb +0 -0
- data/mod/{standard → 05_standard}/file/103/icon-6566.ico +0 -0
- data/mod/{standard → 05_standard}/file/103/large-6566.ico +0 -0
- data/mod/{standard → 05_standard}/file/103/medium-6566.ico +0 -0
- data/mod/{standard → 05_standard}/file/103/original-6566.ico +0 -0
- data/mod/{standard → 05_standard}/file/103/small-6566.ico +0 -0
- data/mod/{standard → 05_standard}/file/79/icon-6556.png +0 -0
- data/mod/{standard → 05_standard}/file/79/large-6556.png +0 -0
- data/mod/{standard → 05_standard}/file/79/medium-6556.png +0 -0
- data/mod/{standard → 05_standard}/file/79/original-6556.png +0 -0
- data/mod/{standard → 05_standard}/file/79/small-6556.png +0 -0
- data/mod/{standard → 05_standard}/file/790/icon-6419.png +0 -0
- data/mod/{standard → 05_standard}/file/790/large-6419.png +0 -0
- data/mod/{standard → 05_standard}/file/790/medium-6419.png +0 -0
- data/mod/{standard → 05_standard}/file/790/original-6419.png +0 -0
- data/mod/{standard → 05_standard}/file/790/small-6419.png +0 -0
- data/mod/{standard → 05_standard}/format/css_format.rb +0 -0
- data/mod/{standard → 05_standard}/format/csv_format.rb +0 -0
- data/mod/{standard → 05_standard}/format/file_format.rb +0 -0
- data/mod/{standard → 05_standard}/format/js_format.rb +0 -0
- data/mod/{standard → 05_standard}/format/json_format.rb +0 -0
- data/mod/{standard → 05_standard}/format/rss_format.rb +0 -0
- data/mod/{standard → 05_standard}/format/xml_format.rb +0 -0
- data/mod/{standard → 05_standard}/set/all/account.rb +0 -0
- data/mod/{standard → 05_standard}/set/all/all_css.rb +0 -0
- data/mod/{standard → 05_standard}/set/all/all_csv.rb +1 -1
- data/mod/05_standard/set/all/all_js.rb +7 -0
- data/mod/{standard → 05_standard}/set/all/attach.rb +33 -33
- data/mod/{standard → 05_standard}/set/all/base.rb +0 -0
- data/mod/{standard → 05_standard}/set/all/comment.rb +0 -0
- data/mod/{standard → 05_standard}/set/all/event_viz.rb +0 -0
- data/mod/{standard → 05_standard}/set/all/file.rb +0 -0
- data/mod/05_standard/set/all/follow.rb +51 -0
- data/mod/05_standard/set/all/history.rb +294 -0
- data/mod/{standard → 05_standard}/set/all/json.rb +2 -1
- data/mod/05_standard/set/all/observer.rb +27 -0
- data/mod/{standard → 05_standard}/set/all/rich_html.rb +21 -28
- data/mod/{standard → 05_standard}/set/all/rss.rb +0 -0
- data/mod/{standard → 05_standard}/set/all/text.rb +0 -0
- data/mod/{standard → 05_standard}/set/right/account.rb +53 -7
- data/mod/{standard → 05_standard}/set/right/email.rb +0 -1
- data/mod/{standard → 05_standard}/set/right/password.rb +1 -1
- data/mod/{standard → 05_standard}/set/right/salt.rb +0 -0
- data/mod/{standard → 05_standard}/set/right/stats.rb +1 -1
- data/mod/{standard → 05_standard}/set/right/status.rb +0 -0
- data/mod/{standard → 05_standard}/set/right/token.rb +0 -0
- data/mod/{standard → 05_standard}/set/right/when_created.rb +0 -0
- data/mod/{standard → 05_standard}/set/right/when_last_edited.rb +0 -0
- data/mod/{standard → 05_standard}/set/rstar/rules.rb +8 -7
- data/mod/{standard → 05_standard}/set/self/account_links.rb +0 -0
- data/mod/{standard → 05_standard}/set/self/alerts.rb +0 -0
- data/mod/{standard → 05_standard}/set/self/all.rb +1 -1
- data/mod/{standard → 05_standard}/set/self/foot.rb +0 -0
- data/mod/{standard → 05_standard}/set/self/head.rb +21 -6
- data/mod/{standard → 05_standard}/set/self/navbox.rb +0 -0
- data/mod/{standard → 05_standard}/set/self/now.rb +0 -0
- data/mod/{standard → 05_standard}/set/self/recent.rb +0 -0
- data/mod/{standard → 05_standard}/set/self/search.rb +0 -0
- data/mod/{standard → 05_standard}/set/self/signin.rb +1 -1
- data/mod/{standard → 05_standard}/set/self/stats.rb +2 -2
- data/mod/{standard → 05_standard}/set/self/version.rb +0 -0
- data/mod/{standard → 05_standard}/set/type/basic.rb +0 -0
- data/mod/{standard → 05_standard}/set/type/cardtype.rb +4 -6
- data/mod/{standard → 05_standard}/set/type/date.rb +0 -0
- data/mod/{standard → 05_standard}/set/type/file.rb +0 -0
- data/mod/{standard → 05_standard}/set/type/html.rb +0 -0
- data/mod/{standard → 05_standard}/set/type/image.rb +7 -6
- data/mod/{standard → 05_standard}/set/type/layout_type.rb +0 -0
- data/mod/{standard → 05_standard}/set/type/number.rb +0 -0
- data/mod/{standard → 05_standard}/set/type/phrase.rb +0 -0
- data/mod/{standard → 05_standard}/set/type/search_type.rb +6 -3
- data/mod/{standard → 05_standard}/set/type/set.rb +16 -9
- data/mod/{standard → 05_standard}/set/type/signup.rb +16 -17
- data/mod/{standard → 05_standard}/set/type/toggle.rb +0 -0
- data/mod/{standard → 05_standard}/set/type/user.rb +10 -11
- data/{spec/mod/standard → mod/05_standard/spec}/chunk/include_spec.rb +39 -39
- data/mod/05_standard/spec/chunk/link_spec.rb +61 -0
- data/{spec/mod/standard → mod/05_standard/spec}/format/css_format_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/format/csv_format_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/format/email_html_format_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/format/file_format_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/format/js_format_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/format/json_format_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/format/rss_format_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/format/xml_format_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/account_spec.rb +16 -16
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/all_css_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/all_csv_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/attach_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/base_spec.rb +10 -10
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/comment_spec.rb +0 -0
- data/mod/05_standard/spec/set/all/email_html_spec.rb +15 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/event_viz_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/file_spec.rb +0 -0
- data/mod/05_standard/spec/set/all/follow_spec.rb +83 -0
- data/mod/05_standard/spec/set/all/history_spec.rb +161 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/json_spec.rb +4 -4
- data/mod/05_standard/spec/set/all/observer_spec.rb +74 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/rich_html_spec.rb +14 -14
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/rss_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/all/text_spec.rb +0 -0
- data/mod/05_standard/spec/set/right/account_spec.rb +162 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/right/email_spec.rb +7 -7
- data/{spec/mod/standard → mod/05_standard/spec}/set/right/password_spec.rb +7 -7
- data/{spec/mod/standard → mod/05_standard/spec}/set/right/salt_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/right/stats_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/right/status_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/right/token_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/right/when_created_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/right/when_last_edited_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/rstar/rules_spec.rb +4 -4
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/account_links_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/alerts_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/all_spec.rb +7 -6
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/foot_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/head_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/navbox_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/now_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/recent_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/search_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/signin_spec.rb +12 -12
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/stats_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/self/version_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/basic_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/cardtype_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/date_spec.rb +0 -0
- data/mod/05_standard/spec/set/type/email_template_spec.rb +130 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/file_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/html_spec.rb +3 -3
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/image_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/layout_type_spec.rb +1 -1
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/number_spec.rb +0 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/phrase_spec.rb +0 -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 +209 -0
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/toggle_spec.rb +2 -2
- data/{spec/mod/standard → mod/05_standard/spec}/set/type/user_spec.rb +0 -0
- data/mod/{standard → 06_email}/format/email_html_format.rb +0 -0
- data/mod/06_email/format/email_text_format.rb +7 -0
- data/mod/06_email/set/all/email_html.rb +9 -0
- data/mod/{standard/set/all/email_html.rb → 06_email/set/all/email_text.rb} +2 -1
- data/mod/06_email/set/right/bcc.rb +31 -0
- data/mod/06_email/set/right/cc.rb +2 -0
- data/mod/06_email/set/right/from.rb +2 -0
- data/mod/06_email/set/right/html_message.rb +3 -0
- data/mod/06_email/set/right/to.rb +2 -0
- data/mod/06_email/set/type/email_template.rb +99 -0
- data/spec/controllers/card_controller_spec.rb +34 -46
- data/spec/lib/card/action_spec.rb +14 -0
- data/spec/lib/card/chunk_spec.rb +3 -3
- data/spec/lib/card/codename_spec.rb +5 -5
- data/spec/lib/card/content_spec.rb +25 -25
- data/spec/lib/card/diff_spec.rb +107 -107
- data/spec/lib/card/format_spec.rb +11 -11
- data/spec/lib/card/loader_spec.rb +35 -29
- data/spec/lib/card/name_spec.rb +82 -82
- data/spec/lib/card/query_spec.rb +83 -82
- data/spec/lib/card/reference_spec.rb +30 -30
- data/spec/lib/card/set_pattern_spec.rb +1 -1
- data/spec/lib/card/set_spec.rb +86 -82
- data/spec/lib/wagn/cache_spec.rb +24 -24
- data/spec/mailers/mailer_spec.rb +41 -30
- data/spec/models/card/cardtype_spec.rb +19 -19
- data/spec/models/card/create_spec.rb +14 -14
- data/spec/models/card/trash_spec.rb +37 -36
- data/spec/models/card/type_transition_spec.rb +13 -13
- data/spec/models/card/validation_spec.rb +6 -6
- data/spec/models/card_spec.rb +40 -39
- data/spec/spec_helper.rb +37 -11
- data/test/fixtures/card_actions.yml +4726 -0
- data/test/fixtures/card_acts.yml +589 -0
- data/test/fixtures/card_changes.yml +12644 -0
- data/test/fixtures/card_references.yml +976 -591
- data/test/fixtures/cards.yml +4544 -2781
- data/test/seed.rb +14 -13
- data/wagn.gemspec +4 -0
- metadata +404 -403
- data/db/bootstrap/card_revisions.yml +0 -3379
- data/lib/card/flexmail.rb +0 -53
- data/lib/card/mailer/change_notice.html.erb +0 -32
- data/lib/card/mailer/confirmation_email.html.erb +0 -12
- data/lib/card/mailer/flexmail.html.erb +0 -6
- data/lib/card/mailer/password_reset.html.erb +0 -9
- data/lib/card/mailer/signup_alert.html.erb +0 -14
- data/lib/card/revision.rb +0 -47
- data/lib/wagn/migration_helper.rb +0 -34
- data/mod/core/set/all/attribute_tracking.rb +0 -85
- data/mod/core/set/all/content.rb +0 -94
- data/mod/standard/set/all/flexmail.rb +0 -3
- data/mod/standard/set/all/follow.rb +0 -119
- data/mod/standard/set/all/history.rb +0 -107
- data/mod/standard/set/right/add_help.rb +0 -3
- data/mod/standard/set/right/default.rb +0 -3
- data/mod/standard/set/right/help.rb +0 -3
- data/spec/lib/card/flexmail_spec.rb +0 -209
- data/spec/lib/card/revision_spec.rb +0 -30
- data/spec/mod/core/chunk/literal_spec.rb +0 -14
- data/spec/mod/core/set/all/attribute_tracking_spec.rb +0 -21
- data/spec/mod/core/set/all/collection_spec.rb +0 -45
- data/spec/mod/core/set/all/content_spec.rb +0 -14
- data/spec/mod/core/set/all/rules_spec.rb +0 -98
- data/spec/mod/standard/chunk/link_spec.rb +0 -59
- data/spec/mod/standard/set/all/email_html_spec.rb +0 -13
- data/spec/mod/standard/set/all/flexmail_spec.rb +0 -5
- data/spec/mod/standard/set/all/follow_spec.rb +0 -95
- data/spec/mod/standard/set/all/history_spec.rb +0 -10
- data/spec/mod/standard/set/right/account_spec.rb +0 -90
- data/spec/mod/standard/set/type/search_type_spec.rb +0 -27
- data/spec/mod/standard/set/type/set_spec.rb +0 -26
- data/spec/mod/standard/set/type/signup_spec.rb +0 -169
- data/test/fixtures/card_revisions.yml +0 -4560
@@ -1,21 +1,18 @@
|
|
1
1
|
# -*- encoding : utf-8 -*-
|
2
2
|
|
3
|
-
class UpdateStylesheets <
|
4
|
-
include Wagn::MigrationHelper
|
3
|
+
class UpdateStylesheets < Wagn::Migration
|
5
4
|
def up
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
card.update_attributes! :content=>File.read("#{dir}/#{sheetname}.scss")
|
12
|
-
end
|
13
|
-
end
|
14
|
-
|
15
|
-
if c = Card['*all+*style+file']
|
16
|
-
c.delete!
|
5
|
+
dir = "#{Wagn.gem_root}/db/migrate_cards/data/1.12_stylesheets"
|
6
|
+
%w{ common traditional }.each do |sheetname|
|
7
|
+
card = Card["style: #{sheetname}"]
|
8
|
+
if card && card.pristine?
|
9
|
+
card.update_attributes! :content=>File.read("#{dir}/#{sheetname}.scss")
|
17
10
|
end
|
18
11
|
end
|
12
|
+
|
13
|
+
if c = Card['*all+*style+file']
|
14
|
+
c.delete!
|
15
|
+
end
|
19
16
|
end
|
20
17
|
|
21
18
|
end
|
@@ -1,24 +1,21 @@
|
|
1
1
|
# -*- encoding : utf-8 -*-
|
2
2
|
|
3
|
-
class AccountEvents <
|
4
|
-
include Wagn::MigrationHelper
|
3
|
+
class AccountEvents < Wagn::Migration
|
5
4
|
def up
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
r_input.save!
|
21
|
-
end
|
5
|
+
aa = Card.fetch "#{ Card[ :signup ].name }+#{ Card[ :type ].name}+#{ Card[:accountable ].name}", :new=>{}
|
6
|
+
aa.content = "1"
|
7
|
+
aa.save!
|
8
|
+
|
9
|
+
role_right = "#{ Card[ :roles ].name }+#{ Card[ :right ].name }"
|
10
|
+
|
11
|
+
r_options = Card.fetch "#{ role_right }+#{ Card[ :options ].name }", :new=>{}
|
12
|
+
r_options.type_id = Card::SearchTypeID
|
13
|
+
r_options.content = %({"type":"role", "not":{"codename":["in","anyone","anyone_signed_in"]}})
|
14
|
+
r_options.save!
|
15
|
+
|
16
|
+
r_input = Card.fetch "#{ role_right }+#{ Card[ :input ].name }", :new=>{}
|
17
|
+
r_input.content = '[[checkbox]]'
|
18
|
+
r_input.save!
|
22
19
|
end
|
23
20
|
|
24
21
|
end
|
@@ -1,14 +1,11 @@
|
|
1
1
|
# -*- encoding : utf-8 -*-
|
2
2
|
|
3
|
-
class CommonCssPatch <
|
4
|
-
include Wagn::MigrationHelper
|
3
|
+
class CommonCssPatch < Wagn::Migration
|
5
4
|
def up
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
card.update_attributes! :content=>File.read("#{dir}/common.scss")
|
11
|
-
end
|
5
|
+
dir = "#{Wagn.gem_root}/db/migrate_cards/data/1.12_stylesheets"
|
6
|
+
card = Card["style: common"]
|
7
|
+
if card && card.pristine?
|
8
|
+
card.update_attributes! :content=>File.read("#{dir}/common.scss")
|
12
9
|
end
|
13
10
|
end
|
14
11
|
|
@@ -1,13 +1,10 @@
|
|
1
1
|
# -*- encoding : utf-8 -*-
|
2
2
|
|
3
|
-
class ResetAccountRequestType <
|
4
|
-
include Wagn::MigrationHelper
|
3
|
+
class ResetAccountRequestType < Wagn::Migration
|
5
4
|
def up
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
arcard.update_attributes :type_id=>Card::CardtypeID
|
10
|
-
end
|
5
|
+
arcard = Card[:signup]
|
6
|
+
if arcard.type_code != :cardtype
|
7
|
+
arcard.update_attributes :type_id=>Card::CardtypeID
|
11
8
|
end
|
12
9
|
end
|
13
10
|
|
@@ -3,67 +3,64 @@
|
|
3
3
|
class User < ActiveRecord::Base
|
4
4
|
end
|
5
5
|
|
6
|
-
class UserDataToCards <
|
7
|
-
include Wagn::MigrationHelper
|
6
|
+
class UserDataToCards < Wagn::Migration
|
8
7
|
|
9
8
|
def up
|
10
|
-
contentedly do
|
11
9
|
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
end
|
10
|
+
puts "adding new codename cards"
|
11
|
+
[ :password, :token, :salt, :status, :signin, :stats ].each do |codename|
|
12
|
+
Card.create! :name=>"*#{codename}", :codename=>codename
|
13
|
+
end
|
14
|
+
|
15
|
+
Card::Codename.reset_cache
|
16
|
+
|
17
|
+
puts "setting read permissions for account cards (Administrator)"
|
18
|
+
[ :password, :token, :salt, :status, :email, :account ].each do |codename|
|
19
|
+
rule_name = [ codename, :right, :read ].map { |code| Card[code].name } * '+'
|
20
|
+
rule_card = Card.fetch rule_name, :new=>{}
|
21
|
+
rule_card.content = '[[Administrator]]'
|
22
|
+
rule_card.save!
|
23
|
+
end
|
24
|
+
|
25
|
+
puts "making email and password fields default to Phrase cards"
|
26
|
+
[:email, :password].each do |field|
|
27
|
+
rulename = [field, :right, :default].map { |code| Card[code].name } * '+'
|
28
|
+
Card.create! :name=>rulename, :type_id=>Card::PhraseID
|
29
|
+
end
|
30
|
+
|
31
|
+
puts "signin permissions"
|
32
|
+
[:read, :update].each do |setting|
|
33
|
+
rulename = [ :signin, :self, setting ].map { |code| Card[code].name } * '+'
|
34
|
+
Card.create! :name=>rulename, :content=>"[[#{Card[:anyone].name}]]"
|
35
|
+
end
|
36
|
+
|
37
|
+
puts "supporting legacy handling of +*email on User cards"
|
38
|
+
oldname = [ :email, :right, :structure].map { |code| Card[code].name } * '+'
|
39
|
+
newname = [:user, :email, :type_plus_right, :structure].map { |code| Card[code].name } * '+'
|
40
|
+
Card[oldname].update_attributes! :name=>newname
|
41
|
+
|
42
|
+
|
43
|
+
puts "importing all user details (for those not in trash) into +*account attributes"
|
44
|
+
Card::Env[:no_password_encryptions] = true
|
45
|
+
User.all.each do |user|
|
46
|
+
base = Card[user.card_id]
|
47
|
+
if base and !base.trash
|
48
|
+
puts "~ importing details for #{base.name}"
|
49
|
+
date_args = { :created_at => user.created_at, :updated_at => user.updated_at }
|
50
|
+
[ :email, :salt, :password, :status ].each do |field|
|
51
|
+
cardname = "#{base.name}+#{Card[:account].name}+#{Card[field].name}"
|
52
|
+
user_field = ( field==:password ? :crypted_password : field )
|
53
|
+
if content = user.send( user_field )
|
54
|
+
begin
|
55
|
+
Card.create! date_args.merge( :name=>cardname, :content=>content)
|
56
|
+
rescue => e
|
57
|
+
puts "error importing #{cardname}: #{e.message}"
|
61
58
|
end
|
62
59
|
end
|
63
60
|
end
|
64
61
|
end
|
65
|
-
|
66
62
|
end
|
63
|
+
|
67
64
|
end
|
68
65
|
|
69
66
|
end
|
@@ -1,52 +1,49 @@
|
|
1
1
|
# -*- encoding : utf-8 -*-
|
2
2
|
|
3
|
-
class AccountRequestsToSignups <
|
4
|
-
include Wagn::MigrationHelper
|
3
|
+
class AccountRequestsToSignups < Wagn::Migration
|
5
4
|
def up
|
6
|
-
contentedly do
|
7
5
|
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
6
|
+
newname = 'Sign up'
|
7
|
+
newname = '*signup' if Card.exists? newname
|
8
|
+
|
9
|
+
#get old codename and name out of the way
|
10
|
+
old_signup = Card[:signup]
|
11
|
+
old_signup_name = old_signup.name
|
12
|
+
old_signup.name = "#{newname} - old"
|
13
|
+
old_signup.codename = nil
|
14
|
+
old_signup.save!
|
17
15
|
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
16
|
+
Card::Codename.reset_cache
|
17
|
+
|
18
|
+
# rename Account Request to "Sign up"
|
19
|
+
new_signup = Card[:account_request]
|
20
|
+
new_signup.name = newname
|
21
|
+
new_signup.update_referencers = true
|
22
|
+
new_signup.codename = :signup
|
23
|
+
new_signup.save!
|
26
24
|
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
end
|
36
|
-
|
37
|
-
# get rid of old signup card unless there is other data there (most likely +*subject and +*message)
|
38
|
-
unless Card.search(:return=>:id, :left_id=>old_signup.id).first
|
39
|
-
old_signup.delete!
|
40
|
-
end
|
41
|
-
|
42
|
-
# turn captcha off by default on signup
|
43
|
-
rulename = [:signup, :type, :captcha].map { |code| Card[code].name } * '+'
|
44
|
-
captcha_rule = Card.fetch rulename, :new=>{}
|
45
|
-
captcha_rule.content = '0'
|
46
|
-
captcha_rule.save!
|
47
|
-
|
48
|
-
|
25
|
+
Card::Codename.reset_cache
|
26
|
+
|
27
|
+
# move old "*signup+*thanks" to "Sign up+*type+*thanks"
|
28
|
+
thanks = Card[:thanks]
|
29
|
+
if signup_thanks = Card["#{old_signup.name}+#{thanks.name}"]
|
30
|
+
signup_thanks.name = "#{new_signup.name}+#{Card[:type].name}+#{thanks.name}"
|
31
|
+
signup_thanks.update_referencers = true
|
32
|
+
signup_thanks.save!
|
49
33
|
end
|
34
|
+
|
35
|
+
# get rid of old signup card unless there is other data there (most likely +*subject and +*message)
|
36
|
+
unless Card.search(:return=>:id, :left_id=>old_signup.id).first
|
37
|
+
old_signup.delete!
|
38
|
+
end
|
39
|
+
|
40
|
+
# turn captcha off by default on signup
|
41
|
+
rulename = [:signup, :type, :captcha].map { |code| Card[code].name } * '+'
|
42
|
+
captcha_rule = Card.fetch rulename, :new=>{}
|
43
|
+
captcha_rule.content = '0'
|
44
|
+
captcha_rule.save!
|
45
|
+
|
46
|
+
|
50
47
|
end
|
51
48
|
|
52
49
|
end
|
@@ -20,67 +20,64 @@ class Card
|
|
20
20
|
end
|
21
21
|
end
|
22
22
|
|
23
|
-
class AddScriptCards <
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
Card.gimme!( "#{type}+#{Card[:type].name}+#{Card[action].name}",
|
45
|
-
:content=>"[[#{Card[:administrator].name}]]")
|
46
|
-
end
|
47
|
-
end
|
48
|
-
|
49
|
-
# +*script rules
|
50
|
-
Card.create! :name=>'*script', :codename=>:script, :type_id=>Card::SettingID
|
51
|
-
script_set = "*script+#{Card[:right].name}"
|
52
|
-
Card.create! :name=>"#{script_set}+#{Card[:default].name}", :type_id=>Card::PointerID
|
53
|
-
Card.create! :name=>"#{script_set}+#{Card[:read].name}", :content=>"[[#{Card[:anyone].name}]]"
|
54
|
-
Card.create! :name=>"#{script_set}+#{Card[:options].name}", :content=>%( {"type":["in", "JavaScript", "CoffeeScript"] }), :type=>Card::SearchTypeID
|
55
|
-
Card.create! :name=>"#{script_set}+#{Card[:input].name}", :content=>'list'
|
56
|
-
Card.create! :name=>"#{script_set}+#{Card[:help].name}", :content=>
|
57
|
-
%{ JavaScript (or CoffeeScript) for card's page. } #TODO help link?
|
58
|
-
|
59
|
-
|
60
|
-
# Machine inputs and outputs
|
61
|
-
default_rule_ending = "#{ Card[:right].name }+#{ Card[ :default ].name }"
|
62
|
-
Card.create! :name=>'*machine output', :codename=>:machine_output
|
63
|
-
Card.create! :name=>"*machine output+#{default_rule_ending}", :type_id=>Card::FileID
|
64
|
-
Card.create! :name=>"*machine output+#{ Card[:right].name}+#{Card[:read].name}", :content=>'_left'
|
65
|
-
Card.create! :name=>'*machine input', :codename=>:machine_input
|
66
|
-
Card.create! :name=>"*machine input+#{default_rule_ending}", :type_id=>Card::PointerID
|
67
|
-
|
68
|
-
# create default script rule
|
69
|
-
card_type = { 'js' => "java_script", 'coffee' => "coffee_script"}
|
70
|
-
scripts = %w{ jquery tinymce slot card_menu jquery_helper html5shiv_printshiv }
|
71
|
-
types = %w{ js js coffee js js js }
|
72
|
-
# jquery.mobile (in jquery_helper) must be after wagn to avoid mobileinit nastiness
|
73
|
-
cardnames = scripts.map { |name| "script: #{name.gsub( '_', ' ' )}" }
|
74
|
-
|
75
|
-
scripts.each_with_index do |name, index|
|
76
|
-
Card.create! :name=>cardnames[index], :type=>card_type[types[index]], :codename=>"script_#{name}"
|
23
|
+
class AddScriptCards < Wagn::Migration
|
24
|
+
def up
|
25
|
+
# JavaScript and CoffeeScript types
|
26
|
+
card = Card.fetch "CoffeeScript", :new => {}
|
27
|
+
card.codename = "coffee_script"
|
28
|
+
card.type_id = Card::CardtypeID
|
29
|
+
card.save!
|
30
|
+
|
31
|
+
card = Card.fetch "JavaScript", :new => {}
|
32
|
+
card.codename = "java_script"
|
33
|
+
card.type_id = Card::CardtypeID
|
34
|
+
card.save!
|
35
|
+
#Card.create! :name=>'JavaScript', :codename=>:java_script, :type_id=>Card::CardtypeID
|
36
|
+
#Card.create! :name=>'CoffeeScript', :codename=>:coffee_script, :type_id=>Card::CardtypeID
|
37
|
+
|
38
|
+
# Permissions for JavaScript and CoffeeScript types
|
39
|
+
# ( the same as for CSS and SCSS)
|
40
|
+
['JavaScript', 'CoffeeScript'].each do |type|
|
41
|
+
[ :create, :update, :delete].each do |action|
|
42
|
+
Card.gimme!( "#{type}+#{Card[:type].name}+#{Card[action].name}",
|
43
|
+
:content=>"[[#{Card[:administrator].name}]]")
|
77
44
|
end
|
78
|
-
|
79
|
-
cardnames.pop # html5shiv_printshiv not in default list, only used for IE9 (handled in head.rb)
|
80
|
-
Wagn::Cache.reset_global
|
81
|
-
Card.create! :name=>"#{Card[:all].name}+*script", :content=>cardnames.map { |name| "[[#{ name }]]" }.join("\n")
|
82
|
-
|
83
45
|
end
|
46
|
+
|
47
|
+
# +*script rules
|
48
|
+
Card.create! :name=>'*script', :codename=>:script, :type_id=>Card::SettingID
|
49
|
+
script_set = "*script+#{Card[:right].name}"
|
50
|
+
Card.create! :name=>"#{script_set}+#{Card[:default].name}", :type_id=>Card::PointerID
|
51
|
+
Card.create! :name=>"#{script_set}+#{Card[:read].name}", :content=>"[[#{Card[:anyone].name}]]"
|
52
|
+
Card.create! :name=>"#{script_set}+#{Card[:options].name}", :content=>%( {"type":["in", "JavaScript", "CoffeeScript"] }), :type=>Card::SearchTypeID
|
53
|
+
Card.create! :name=>"#{script_set}+#{Card[:input].name}", :content=>'list'
|
54
|
+
Card.create! :name=>"#{script_set}+#{Card[:help].name}", :content=>
|
55
|
+
%{ JavaScript (or CoffeeScript) for card's page. } #TODO help link?
|
56
|
+
|
57
|
+
|
58
|
+
# Machine inputs and outputs
|
59
|
+
default_rule_ending = "#{ Card[:right].name }+#{ Card[ :default ].name }"
|
60
|
+
Card.create! :name=>'*machine output', :codename=>:machine_output
|
61
|
+
Card.create! :name=>"*machine output+#{default_rule_ending}", :type_id=>Card::FileID
|
62
|
+
Card.create! :name=>"*machine output+#{ Card[:right].name}+#{Card[:read].name}", :content=>'_left'
|
63
|
+
Card.create! :name=>'*machine input', :codename=>:machine_input
|
64
|
+
Card.create! :name=>"*machine input+#{default_rule_ending}", :type_id=>Card::PointerID
|
65
|
+
|
66
|
+
# create default script rule
|
67
|
+
card_type = { 'js' => "java_script", 'coffee' => "coffee_script"}
|
68
|
+
scripts = %w{ jquery tinymce slot card_menu jquery_helper html5shiv_printshiv }
|
69
|
+
types = %w{ js js coffee js js js }
|
70
|
+
# jquery.mobile (in jquery_helper) must be after wagn to avoid mobileinit nastiness
|
71
|
+
cardnames = scripts.map { |name| "script: #{name.gsub( '_', ' ' )}" }
|
72
|
+
|
73
|
+
scripts.each_with_index do |name, index|
|
74
|
+
Card.create! :name=>cardnames[index], :type=>card_type[types[index]], :codename=>"script_#{name}"
|
75
|
+
end
|
76
|
+
|
77
|
+
cardnames.pop # html5shiv_printshiv not in default list, only used for IE9 (handled in head.rb)
|
78
|
+
Wagn::Cache.reset_global
|
79
|
+
Card.create! :name=>"#{Card[:all].name}+*script", :content=>cardnames.map { |name| "[[#{ name }]]" }.join("\n")
|
80
|
+
|
84
81
|
end
|
85
82
|
end
|
86
83
|
|
@@ -0,0 +1,168 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
2
|
+
|
3
|
+
class AddEmailCards < Wagn::Migration
|
4
|
+
def up
|
5
|
+
|
6
|
+
# change notification rules
|
7
|
+
%w( create update delete ).each do |action|
|
8
|
+
Card.create! :name => "*on #{action}", :type_code=>:setting, :codename=>"on_#{action}"
|
9
|
+
Card.create! :name => "*on #{action}+*right+*help", :content=>"Configures email to be sent when card is #{action}d."
|
10
|
+
Card.create! :name => "*on #{action}+*right+*default", :type_code=>:pointer
|
11
|
+
end
|
12
|
+
|
13
|
+
# change email address list fields to pointers
|
14
|
+
[:to, :from, :cc, :bcc].each do |field|
|
15
|
+
set = Card[field].fetch(:trait=>:right, :new=>{})
|
16
|
+
default_rule = set.fetch(:trait=>:default, :new=>{})
|
17
|
+
default_rule.type_id = Card::PointerID
|
18
|
+
default_rule.save!
|
19
|
+
|
20
|
+
Card.search( :right=>{:codename=>field.to_s} ).each do |field_card|
|
21
|
+
field_card.update_attributes! :type_id => Card::PointerID
|
22
|
+
end
|
23
|
+
|
24
|
+
options_rule = set.fetch(:trait=>:options, :new=>{ :type_code=>:search_type })
|
25
|
+
options_rule.type_id = Card::SearchTypeID
|
26
|
+
options_rule.content = %( { "right_plus":{"codename":"account"} } )
|
27
|
+
options_rule.save!
|
28
|
+
end
|
29
|
+
|
30
|
+
|
31
|
+
# create new cardtype for email templates
|
32
|
+
Card.create! :name=>"Email template", :codename=>:email_template, :type_id=>Card::CardtypeID
|
33
|
+
Card.create! :name=>"Email template+*type+*structure", :content=>%(
|
34
|
+
{{+#{Card[:from].name} | labeled | link}}
|
35
|
+
{{+#{Card[:to ].name} | labeled | link}}
|
36
|
+
{{+#{Card[:cc ].name} | labeled | link}}
|
37
|
+
{{+#{Card[:bcc ].name} | labeled | link}}
|
38
|
+
{{+*subject | titled}}
|
39
|
+
{{+*html message | titled}}
|
40
|
+
{{+*text message | titled}}
|
41
|
+
{+*attach | titled}}
|
42
|
+
)
|
43
|
+
|
44
|
+
c = Card.fetch '*message', :new=>{ }
|
45
|
+
c.name = '*html message'
|
46
|
+
c.codename = 'html_message'
|
47
|
+
c.save!
|
48
|
+
|
49
|
+
Card.create! :name=>'*text message', :codename=>'text_message'
|
50
|
+
Card.create! :name=>"*text message+*right+*default", :type_code=>:plain_text
|
51
|
+
|
52
|
+
|
53
|
+
Wagn::Cache.reset_global
|
54
|
+
|
55
|
+
|
56
|
+
# create system email cards
|
57
|
+
dir = "#{Wagn.gem_root}/db/migrate_cards/data/mailer"
|
58
|
+
json = File.read( File.join( dir, 'mail_config.json' ))
|
59
|
+
data = JSON.parse(json)
|
60
|
+
data.each do |mail|
|
61
|
+
mail = mail.symbolize_keys!
|
62
|
+
Card.create! :name=> mail[:name], :codename=>mail[:codename], :type_id=>Card::EmailTemplateID
|
63
|
+
Card.create! :name=>"#{mail[:name]}+*html message", :content=>File.read( File.join( dir, "#{mail[:codename]}.html" ))
|
64
|
+
Card.create! :name=>"#{mail[:name]}+*text message", :content=>File.read( File.join( dir, "#{mail[:codename]}.txt" ))
|
65
|
+
Card.create! :name=>"#{mail[:name]}+*subject", :content=>mail[:subject]
|
66
|
+
end
|
67
|
+
|
68
|
+
|
69
|
+
# move old hard-coded signup alert email handling to new card-based on_create handling
|
70
|
+
Card.create!(
|
71
|
+
:name=>( [:signup, :type, :on_create].map { |code| Card[code].name } * '+'),
|
72
|
+
:type_id=>Card::PointerID, :content=>"[[signup alert email]]"
|
73
|
+
)
|
74
|
+
if request_card = Card[:request]
|
75
|
+
[:to, :from].each do |field|
|
76
|
+
if old_card = request_card.fetch(:trait=>field) and !old_card.content.blank?
|
77
|
+
Card.create! :name=>"signup alert email+#{Card[field].name}", :content=>old_card.content
|
78
|
+
end
|
79
|
+
end
|
80
|
+
request_card.codename = nil
|
81
|
+
request_card.delete!
|
82
|
+
end
|
83
|
+
|
84
|
+
# update *from settings
|
85
|
+
|
86
|
+
signup_alert_from = Card["signup alert email"].fetch(:trait=>:from, :new=>{})
|
87
|
+
if signup_alert_from.content.blank?
|
88
|
+
signup_alert_from.content = '_user'
|
89
|
+
signup_alert_from.save!
|
90
|
+
end
|
91
|
+
|
92
|
+
wagn_bot = Card[:wagn_bot].account.email.present? ? Card[:wagn_bot].name : nil
|
93
|
+
token_emails_from = Card.setting( '*invite+*from' ) || wagn_bot || '_user'
|
94
|
+
[ 'verification email', 'password reset email'].each do |token_email_template_name|
|
95
|
+
Card.create! :name=>"#{token_email_template_name}+#{Card[:from].name}", :content=>token_emails_from
|
96
|
+
end
|
97
|
+
|
98
|
+
if invite_card = Card[:invite]
|
99
|
+
invite_card.codename = nil
|
100
|
+
invite_card.delete!
|
101
|
+
end
|
102
|
+
|
103
|
+
|
104
|
+
# migrate old flexmail cards
|
105
|
+
|
106
|
+
if email_config_card = Card['email_config']
|
107
|
+
Card.search(
|
108
|
+
:left=>{ :type_id=>Card::SetID },
|
109
|
+
:right=>'email_config',
|
110
|
+
:referred_to_by=>{ :right=>{:codename=>'send'} }
|
111
|
+
).each do |card|
|
112
|
+
set_name = card.cardname.left
|
113
|
+
card.name = "#{ set_name.gsub('*','' ).gsub('+', '_') }_email_template"
|
114
|
+
card.type_code = 'email_template'
|
115
|
+
card.save!
|
116
|
+
Card.create! :name=>"#{set_name}+*on create", :content=>card.name
|
117
|
+
end
|
118
|
+
|
119
|
+
email_config_card.delete!
|
120
|
+
end
|
121
|
+
|
122
|
+
|
123
|
+
|
124
|
+
# move old send rule to on_create
|
125
|
+
#fields = %w( to from cc bcc subject message attach )
|
126
|
+
Card.search(:right=>"*send").each do |send_rule|
|
127
|
+
Card.create! :name=>"send_rule.left+*on create", :content=>send_rule.content, :type_code=>:pointer
|
128
|
+
send_rule.delete #@ethn: keep old rule for safety reasons?
|
129
|
+
end
|
130
|
+
|
131
|
+
# the new following rule
|
132
|
+
Card.create! :name => '*following', :type_code=>:pointer, :codename=>'following'
|
133
|
+
Card.create! :name => '*following+*right+*default', :type_code=>:pointer
|
134
|
+
Card.create! :name => '*following+*right+*update', :content=>'_left'
|
135
|
+
Card.create! :name => '*following+*right+*create', :content=>'_left'
|
136
|
+
Card::Codename.reset_cache
|
137
|
+
|
138
|
+
# move old watch rules
|
139
|
+
# +watchers
|
140
|
+
follower_hash = Hash.new { |h, v| h[v] = [] }
|
141
|
+
|
142
|
+
Card.search(:right_plus => {:codename=> "watchers"}).each do |card|
|
143
|
+
if watched = card.left
|
144
|
+
card.item_names.each do |user_name|
|
145
|
+
follower_hash[user_name] << watched.name
|
146
|
+
end
|
147
|
+
end
|
148
|
+
end
|
149
|
+
|
150
|
+
follower_hash.each do |user, items|
|
151
|
+
if card=Card.fetch(user) and card.account
|
152
|
+
following = card.fetch :trait=>"following", :new=>{}
|
153
|
+
following.items = items
|
154
|
+
end
|
155
|
+
end
|
156
|
+
|
157
|
+
if watchers = Card[:watchers]
|
158
|
+
watchers.update_attributes :codename=>nil
|
159
|
+
watchers.delete!
|
160
|
+
end
|
161
|
+
|
162
|
+
if send = Card[:send]
|
163
|
+
send.update_attributes :codename=>nil
|
164
|
+
send.delete!
|
165
|
+
end
|
166
|
+
end
|
167
|
+
end
|
168
|
+
|