card 1.16.1 → 1.16.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.yardoc/checksums +60 -0
- data/.yardoc/object_types +0 -0
- data/.yardoc/objects/root.dat +0 -0
- data/.yardoc/proxy_types +0 -0
- data/.yardopts +6 -0
- data/README_Developers.rdoc +100 -0
- data/VERSION +1 -1
- data/card.gemspec +18 -18
- data/db/migrate/20150724210803_add_comment_to_actions.rb +5 -0
- data/db/migrate_core_cards/20150724123438_update_file_and_image_cards.rb +70 -0
- data/db/migrate_core_cards/20150807205221_create_references_for_search_cards.rb +10 -0
- data/db/migrate_core_cards/data/1.12_stylesheets/common.scss +4 -2
- data/db/schema.rb +2 -1
- data/db/seed/new/card_actions.yml +2334 -12538
- data/db/seed/new/card_acts.yml +1 -1
- data/db/seed/new/card_changes.yml +7384 -38929
- data/db/seed/new/card_references.yml +207 -207
- data/db/seed/new/cards.yml +1364 -1440
- data/db/seed/test/fixtures/card_actions.yml +3285 -13219
- data/db/seed/test/fixtures/card_acts.yml +107 -107
- data/db/seed/test/fixtures/card_changes.yml +10830 -42375
- data/db/seed/test/fixtures/card_references.yml +393 -393
- data/db/seed/test/fixtures/cards.yml +1701 -1777
- data/db/version.txt +1 -1
- data/db/version_core_cards.txt +1 -1
- data/lib/card.rb +13 -3
- data/lib/card/chunk.rb +22 -15
- data/lib/card/content.rb +9 -8
- data/lib/card/diff.rb +79 -79
- data/lib/card/loader.rb +33 -33
- data/lib/card/name.rb +8 -0
- data/lib/card/set.rb +44 -17
- data/lib/card/set_pattern.rb +8 -0
- data/lib/cardio.rb +19 -3
- data/mod/01_core/chunk/link.rb +7 -6
- data/mod/01_core/chunk/query_reference.rb +65 -0
- data/mod/01_core/set/all/content.rb +1 -1
- data/mod/01_core/set/all/fetch.rb +15 -7
- data/mod/01_core/set/all/initialize.rb +4 -3
- data/mod/01_core/set/all/phases.rb +12 -8
- data/mod/01_core/set/all/references.rb +12 -6
- data/mod/01_core/set/all/rules.rb +14 -11
- data/mod/01_core/set/all/states.rb +2 -1
- data/mod/01_core/set/all/tracked_attributes.rb +14 -0
- data/mod/01_core/spec/set/all/collection_spec.rb +5 -5
- data/mod/01_core/spec/set/all/name_spec.rb +6 -6
- data/mod/01_history/lib/card/act.rb +2 -2
- data/mod/01_history/lib/card/action.rb +11 -2
- data/mod/01_history/set/all/actions.rb +4 -3
- data/mod/01_history/set/all/content_history.rb +1 -1
- data/mod/01_history/set/all/history.rb +55 -66
- data/mod/02_basic_types/set/all/file.rb +26 -3
- data/mod/02_basic_types/set/type/pointer.rb +13 -14
- data/mod/02_basic_types/spec/set/all/file_spec.rb +0 -1
- data/mod/03_machines/lib/card/machine.rb +4 -4
- data/mod/03_machines/lib/javascript/wagn_mod.js.coffee +4 -17
- data/mod/03_machines/lib/stylesheets/style_cards.scss +5 -0
- data/mod/03_machines/set/right/machine_input.rb +3 -0
- data/mod/03_machines/set/right/machine_output.rb +4 -0
- data/mod/04_settings/lib/card/setting.rb +2 -1
- data/mod/04_settings/set/abstract/permission.rb +95 -0
- data/mod/04_settings/set/right/comment.rb +2 -90
- data/mod/04_settings/set/right/create.rb +2 -2
- data/mod/04_settings/set/right/delete.rb +2 -3
- data/mod/04_settings/set/right/read.rb +3 -2
- data/mod/04_settings/set/right/update.rb +3 -2
- data/mod/04_settings/set/self/recent_settings.rb +3 -0
- data/mod/04_settings/set/type/setting.rb +9 -1
- data/mod/05_email/set/all/notify.rb +2 -1
- data/mod/05_email/set/type/email_template.rb +17 -17
- data/mod/05_standard/file/credit_image/image-icon.png +0 -0
- data/mod/05_standard/file/credit_image/image-large.png +0 -0
- data/mod/05_standard/file/credit_image/image-medium.png +0 -0
- data/mod/05_standard/file/credit_image/image-original.png +0 -0
- data/mod/05_standard/file/credit_image/image-small.png +0 -0
- data/mod/05_standard/file/favicon/{icon-image.png → image-icon.png} +0 -0
- data/mod/05_standard/file/favicon/{large-image.png → image-large.png} +0 -0
- data/mod/05_standard/file/favicon/{medium-image.png → image-medium.png} +0 -0
- data/mod/05_standard/file/favicon/{original-image.png → image-original.png} +0 -0
- data/mod/05_standard/file/favicon/{small-image.png → image-small.png} +0 -0
- data/mod/05_standard/file/logo/{icon-image.png → image-icon.png} +0 -0
- data/mod/05_standard/file/logo/{large-image.png → image-large.png} +0 -0
- data/mod/05_standard/file/logo/{medium-image.png → image-medium.png} +0 -0
- data/mod/05_standard/file/logo/{original-image.png → image-original.png} +0 -0
- data/mod/05_standard/file/logo/{small-image.png → image-small.png} +0 -0
- data/mod/05_standard/lib/carrier_wave/cardmount.rb +79 -0
- data/mod/05_standard/lib/file_uploader.rb +127 -0
- data/mod/05_standard/lib/image_uploader.rb +35 -0
- data/mod/05_standard/set/abstract/attachment.rb +85 -0
- data/mod/05_standard/set/all/error.rb +1 -18
- data/mod/05_standard/set/all/event_viz.rb +17 -14
- data/mod/05_standard/set/all/rich_html/editing.rb +10 -10
- data/mod/05_standard/set/all/rich_html/toolbar.rb +44 -37
- data/mod/05_standard/set/right/account.rb +1 -1
- data/mod/05_standard/set/right/password.rb +9 -10
- data/mod/05_standard/set/self/recent.rb +1 -1
- data/mod/05_standard/set/type/file.rb +43 -31
- data/mod/05_standard/set/type/image.rb +22 -6
- data/mod/05_standard/set/type/search_type.rb +4 -2
- data/mod/05_standard/set/type/session.rb +7 -5
- data/mod/05_standard/set/type/set.rb +3 -1
- data/mod/05_standard/spec/set/all/history_spec.rb +1 -1
- data/mod/05_standard/spec/set/type/cardtype_spec.rb +3 -3
- data/mod/05_standard/spec/set/type/file_spec.rb +85 -1
- data/mod/05_standard/spec/set/type/image_spec.rb +89 -5
- data/mod/05_standard/spec/set/type/search_type_spec.rb +16 -1
- data/mod/06_bootstrap/file/{cerulean_skin/icon-image.png → cerulean_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{cerulean_skin/large-image.png → cerulean_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{cerulean_skin/medium-image.png → cerulean_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{cerulean_skin/original-image.png → cerulean_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{cerulean_skin/small-image.png → cerulean_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{cosmo_skin/icon-image.png → cosmo_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{cosmo_skin/large-image.png → cosmo_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{cosmo_skin/medium-image.png → cosmo_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{cosmo_skin/original-image.png → cosmo_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{cosmo_skin/small-image.png → cosmo_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{cyborg_skin/icon-image.png → cyborg_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{cyborg_skin/large-image.png → cyborg_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{cyborg_skin/medium-image.png → cyborg_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{cyborg_skin/original-image.png → cyborg_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{cyborg_skin/small-image.png → cyborg_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{darkly_skin/icon-image.png → darkly_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{darkly_skin/large-image.png → darkly_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{darkly_skin/medium-image.png → darkly_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{darkly_skin/original-image.png → darkly_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{darkly_skin/small-image.png → darkly_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{flatly_skin/icon-image.png → flatly_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{flatly_skin/large-image.png → flatly_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{flatly_skin/medium-image.png → flatly_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{flatly_skin/original-image.png → flatly_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{flatly_skin/small-image.png → flatly_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{journal_skin/icon-image.png → journal_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{journal_skin/large-image.png → journal_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{journal_skin/medium-image.png → journal_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{journal_skin/original-image.png → journal_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{journal_skin/small-image.png → journal_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{lumen_skin/icon-image.png → lumen_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{lumen_skin/large-image.png → lumen_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{lumen_skin/medium-image.png → lumen_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{lumen_skin/original-image.png → lumen_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{lumen_skin/small-image.png → lumen_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{paper_skin/icon-image.png → paper_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{paper_skin/large-image.png → paper_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{paper_skin/medium-image.png → paper_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{paper_skin/original-image.png → paper_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{paper_skin/small-image.png → paper_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{readable_skin/icon-image.png → readable_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{readable_skin/large-image.png → readable_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{readable_skin/medium-image.png → readable_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{readable_skin/original-image.png → readable_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{readable_skin/small-image.png → readable_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{sandstone_skin/icon-image.png → sandstone_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{sandstone_skin/large-image.png → sandstone_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{sandstone_skin/medium-image.png → sandstone_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{sandstone_skin/original-image.png → sandstone_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{sandstone_skin/small-image.png → sandstone_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{simplex_skin/icon-image.png → simplex_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{simplex_skin/large-image.png → simplex_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{simplex_skin/medium-image.png → simplex_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{simplex_skin/original-image.png → simplex_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{simplex_skin/small-image.png → simplex_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{slate_skin/icon-image.png → slate_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{slate_skin/large-image.png → slate_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{slate_skin/medium-image.png → slate_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{slate_skin/original-image.png → slate_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{slate_skin/small-image.png → slate_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{spacelab_skin/icon-image.png → spacelab_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{spacelab_skin/large-image.png → spacelab_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{spacelab_skin/medium-image.png → spacelab_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{spacelab_skin/original-image.png → spacelab_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{spacelab_skin/small-image.png → spacelab_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{superhero_skin/icon-image.png → superhero_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{superhero_skin/large-image.png → superhero_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{superhero_skin/medium-image.png → superhero_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{superhero_skin/original-image.png → superhero_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{superhero_skin/small-image.png → superhero_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{united_skin/icon-image.png → united_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{united_skin/large-image.png → united_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{united_skin/medium-image.png → united_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{united_skin/original-image.png → united_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{united_skin/small-image.png → united_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/file/{yeti_skin/icon-image.png → yeti_skin_image/image-icon.png} +0 -0
- data/mod/06_bootstrap/file/{yeti_skin/large-image.png → yeti_skin_image/image-large.png} +0 -0
- data/mod/06_bootstrap/file/{yeti_skin/medium-image.png → yeti_skin_image/image-medium.png} +0 -0
- data/mod/06_bootstrap/file/{yeti_skin/original-image.png → yeti_skin_image/image-original.png} +0 -0
- data/mod/06_bootstrap/file/{yeti_skin/small-image.png → yeti_skin_image/image-small.png} +0 -0
- data/mod/06_bootstrap/lib/stylesheets/bootstrap_cards.scss +5 -3
- data/spec/lib/card/reference_spec.rb +8 -1
- data/tmpsets/README.md +2 -0
- data/tmpsets/set/mod001-01_core/all/active_card.rb +40 -0
- data/tmpsets/set/mod001-01_core/all/collection.rb +348 -0
- data/tmpsets/set/mod001-01_core/all/content.rb +68 -0
- data/tmpsets/set/mod001-01_core/all/erb.rb +17 -0
- data/tmpsets/set/mod001-01_core/all/fetch.rb +242 -0
- data/tmpsets/set/mod001-01_core/all/haml.rb +13 -0
- data/tmpsets/set/mod001-01_core/all/initialize.rb +56 -0
- data/tmpsets/set/mod001-01_core/all/name.rb +279 -0
- data/tmpsets/set/mod001-01_core/all/pattern.rb +62 -0
- data/tmpsets/set/mod001-01_core/all/permissions.rb +289 -0
- data/tmpsets/set/mod001-01_core/all/phases.rb +187 -0
- data/tmpsets/set/mod001-01_core/all/references.rb +130 -0
- data/tmpsets/set/mod001-01_core/all/rules.rb +324 -0
- data/tmpsets/set/mod001-01_core/all/states.rb +28 -0
- data/tmpsets/set/mod001-01_core/all/templating.rb +132 -0
- data/tmpsets/set/mod001-01_core/all/tracked_attributes.rb +136 -0
- data/tmpsets/set/mod001-01_core/all/trash.rb +56 -0
- data/tmpsets/set/mod001-01_core/all/type.rb +91 -0
- data/tmpsets/set/mod001-01_core/all/utils.rb +162 -0
- data/tmpsets/set/mod001-01_core/all/view_cache.rb +14 -0
- data/tmpsets/set/mod002-01_history/all/actions.rb +54 -0
- data/tmpsets/set/mod002-01_history/all/content_history.rb +140 -0
- data/tmpsets/set/mod002-01_history/all/history.rb +341 -0
- data/tmpsets/set/mod003-02_basic_types/all/all_css.rb +48 -0
- data/tmpsets/set/mod003-02_basic_types/all/all_csv.rb +58 -0
- data/tmpsets/set/mod003-02_basic_types/all/all_js.rb +13 -0
- data/tmpsets/set/mod003-02_basic_types/all/base.rb +128 -0
- data/tmpsets/set/mod003-02_basic_types/all/file.rb +42 -0
- data/tmpsets/set/mod003-02_basic_types/all/json.rb +72 -0
- data/tmpsets/set/mod003-02_basic_types/all/rss.rb +78 -0
- data/tmpsets/set/mod003-02_basic_types/all/text.rb +14 -0
- data/tmpsets/set/mod003-02_basic_types/type/html.rb +33 -0
- data/tmpsets/set/mod003-02_basic_types/type/plain_text.rb +16 -0
- data/tmpsets/set/mod003-02_basic_types/type/pointer.rb +358 -0
- data/tmpsets/set/mod004-03_machines/right/machine_input.rb +8 -0
- data/tmpsets/set/mod004-03_machines/right/machine_output.rb +30 -0
- data/tmpsets/set/mod004-03_machines/self/script_ace.rb +18 -0
- data/tmpsets/set/mod004-03_machines/self/script_card_menu.rb +17 -0
- data/tmpsets/set/mod004-03_machines/self/script_html5shiv_printshiv.rb +8 -0
- data/tmpsets/set/mod004-03_machines/self/script_jquery.rb +8 -0
- data/tmpsets/set/mod004-03_machines/self/script_jquery_helper.rb +18 -0
- data/tmpsets/set/mod004-03_machines/self/script_slot.rb +13 -0
- data/tmpsets/set/mod004-03_machines/self/script_tinymce.rb +8 -0
- data/tmpsets/set/mod004-03_machines/self/style_bootstrap_compatible.rb +11 -0
- data/tmpsets/set/mod004-03_machines/self/style_cards.rb +12 -0
- data/tmpsets/set/mod004-03_machines/self/style_jquery_ui_smoothness.rb +9 -0
- data/tmpsets/set/mod004-03_machines/type/coffee_script.rb +67 -0
- data/tmpsets/set/mod004-03_machines/type/css.rb +55 -0
- data/tmpsets/set/mod004-03_machines/type/java_script.rb +43 -0
- data/tmpsets/set/mod004-03_machines/type/scss.rb +28 -0
- data/tmpsets/set/mod004-03_machines/type/skin.rb +18 -0
- data/tmpsets/set/mod005-04_settings/abstract/permission.rb +101 -0
- data/tmpsets/set/mod005-04_settings/right/add_help.rb +17 -0
- data/tmpsets/set/mod005-04_settings/right/comment.rb +9 -0
- data/tmpsets/set/mod005-04_settings/right/create.rb +9 -0
- data/tmpsets/set/mod005-04_settings/right/default.rb +9 -0
- data/tmpsets/set/mod005-04_settings/right/delete.rb +9 -0
- data/tmpsets/set/mod005-04_settings/right/help.rb +9 -0
- data/tmpsets/set/mod005-04_settings/right/read.rb +9 -0
- data/tmpsets/set/mod005-04_settings/right/script.rb +16 -0
- data/tmpsets/set/mod005-04_settings/right/structure.rb +16 -0
- data/tmpsets/set/mod005-04_settings/right/style.rb +16 -0
- data/tmpsets/set/mod005-04_settings/right/update.rb +9 -0
- data/tmpsets/set/mod005-04_settings/self/accountable.rb +9 -0
- data/tmpsets/set/mod005-04_settings/self/add_help.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/autoname.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/captcha.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/create.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/default.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/delete.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/help.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/input.rb +7 -0
- data/tmpsets/set/mod005-04_settings/self/layout.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/on_create.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/on_delete.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/on_update.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/options.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/options_label.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/read.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/recent_settings.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/script.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/structure.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/style.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/table_of_contents.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/thanks.rb +8 -0
- data/tmpsets/set/mod005-04_settings/self/update.rb +8 -0
- data/tmpsets/set/mod005-04_settings/type/setting.rb +96 -0
- data/tmpsets/set/mod006-05_email/all/email_html.rb +11 -0
- data/tmpsets/set/mod006-05_email/all/email_text.rb +11 -0
- data/tmpsets/set/mod006-05_email/all/follow.rb +260 -0
- data/tmpsets/set/mod006-05_email/all/notify.rb +244 -0
- data/tmpsets/set/mod006-05_email/all/observer.rb +33 -0
- data/tmpsets/set/mod006-05_email/right/bcc.rb +51 -0
- data/tmpsets/set/mod006-05_email/right/cc.rb +9 -0
- data/tmpsets/set/mod006-05_email/right/follow.rb +90 -0
- data/tmpsets/set/mod006-05_email/right/follow_fields.rb +8 -0
- data/tmpsets/set/mod006-05_email/right/followers.rb +35 -0
- data/tmpsets/set/mod006-05_email/right/following.rb +58 -0
- data/tmpsets/set/mod006-05_email/right/from.rb +9 -0
- data/tmpsets/set/mod006-05_email/right/html_message.rb +9 -0
- data/tmpsets/set/mod006-05_email/right/to.rb +9 -0
- data/tmpsets/set/mod006-05_email/self/always.rb +20 -0
- data/tmpsets/set/mod006-05_email/self/created.rb +27 -0
- data/tmpsets/set/mod006-05_email/self/edited.rb +30 -0
- data/tmpsets/set/mod006-05_email/self/follow.rb +8 -0
- data/tmpsets/set/mod006-05_email/self/follow_defaults.rb +71 -0
- data/tmpsets/set/mod006-05_email/self/never.rb +21 -0
- data/tmpsets/set/mod006-05_email/type/email_template.rb +119 -0
- data/tmpsets/set/mod006-05_email/type_plus_right/user/follow.rb +182 -0
- data/tmpsets/set/mod007-05_standard/abstract/attachment.rb +91 -0
- data/tmpsets/set/mod007-05_standard/all/account.rb +73 -0
- data/tmpsets/set/mod007-05_standard/all/comment.rb +45 -0
- data/tmpsets/set/mod007-05_standard/all/error.rb +198 -0
- data/tmpsets/set/mod007-05_standard/all/event_viz.rb +75 -0
- data/tmpsets/set/mod007-05_standard/all/links.rb +153 -0
- data/tmpsets/set/mod007-05_standard/all/rich_html/content.rb +248 -0
- data/tmpsets/set/mod007-05_standard/all/rich_html/editing.rb +216 -0
- data/tmpsets/set/mod007-05_standard/all/rich_html/form.rb +238 -0
- data/tmpsets/set/mod007-05_standard/all/rich_html/header.rb +80 -0
- data/tmpsets/set/mod007-05_standard/all/rich_html/menu.rb +135 -0
- data/tmpsets/set/mod007-05_standard/all/rich_html/modal.rb +98 -0
- data/tmpsets/set/mod007-05_standard/all/rich_html/toolbar.rb +271 -0
- data/tmpsets/set/mod007-05_standard/all/rich_html/wrapper.rb +158 -0
- data/tmpsets/set/mod007-05_standard/right/account.rb +187 -0
- data/tmpsets/set/mod007-05_standard/right/discussion.rb +9 -0
- data/tmpsets/set/mod007-05_standard/right/email.rb +57 -0
- data/tmpsets/set/mod007-05_standard/right/password.rb +44 -0
- data/tmpsets/set/mod007-05_standard/right/salt.rb +11 -0
- data/tmpsets/set/mod007-05_standard/right/stats.rb +41 -0
- data/tmpsets/set/mod007-05_standard/right/status.rb +15 -0
- data/tmpsets/set/mod007-05_standard/right/token.rb +11 -0
- data/tmpsets/set/mod007-05_standard/right/when_created.rb +11 -0
- data/tmpsets/set/mod007-05_standard/right/when_last_edited.rb +11 -0
- data/tmpsets/set/mod007-05_standard/rstar/rules.rb +411 -0
- data/tmpsets/set/mod007-05_standard/self/account_links.rb +55 -0
- data/tmpsets/set/mod007-05_standard/self/alerts.rb +11 -0
- data/tmpsets/set/mod007-05_standard/self/all.rb +28 -0
- data/tmpsets/set/mod007-05_standard/self/foot.rb +14 -0
- data/tmpsets/set/mod007-05_standard/self/head.rb +126 -0
- data/tmpsets/set/mod007-05_standard/self/navbox.rb +39 -0
- data/tmpsets/set/mod007-05_standard/self/now.rb +12 -0
- data/tmpsets/set/mod007-05_standard/self/performance_log.rb +98 -0
- data/tmpsets/set/mod007-05_standard/self/recent.rb +54 -0
- data/tmpsets/set/mod007-05_standard/self/search.rb +49 -0
- data/tmpsets/set/mod007-05_standard/self/signin.rb +130 -0
- data/tmpsets/set/mod007-05_standard/self/stats.rb +109 -0
- data/tmpsets/set/mod007-05_standard/self/version.rb +15 -0
- data/tmpsets/set/mod007-05_standard/type/basic.rb +52 -0
- data/tmpsets/set/mod007-05_standard/type/cardtype.rb +78 -0
- data/tmpsets/set/mod007-05_standard/type/date.rb +14 -0
- data/tmpsets/set/mod007-05_standard/type/file.rb +103 -0
- data/tmpsets/set/mod007-05_standard/type/image.rb +89 -0
- data/tmpsets/set/mod007-05_standard/type/layout_type.rb +21 -0
- data/tmpsets/set/mod007-05_standard/type/number.rb +25 -0
- data/tmpsets/set/mod007-05_standard/type/phrase.rb +9 -0
- data/tmpsets/set/mod007-05_standard/type/search_type.rb +291 -0
- data/tmpsets/set/mod007-05_standard/type/session.rb +42 -0
- data/tmpsets/set/mod007-05_standard/type/set.rb +354 -0
- data/tmpsets/set/mod007-05_standard/type/signup.rb +150 -0
- data/tmpsets/set/mod007-05_standard/type/toggle.rb +18 -0
- data/tmpsets/set/mod007-05_standard/type/uri.rb +17 -0
- data/tmpsets/set/mod007-05_standard/type/user.rb +78 -0
- data/tmpsets/set/mod008-06_bootstrap/all/bootstrap/form.rb +41 -0
- data/tmpsets/set/mod008-06_bootstrap/all/bootstrap/helper.rb +150 -0
- data/tmpsets/set/mod008-06_bootstrap/all/bootstrap/wrapper.rb +18 -0
- data/tmpsets/set/mod008-06_bootstrap/all/rich_bootstrap.rb +14 -0
- data/tmpsets/set/mod008-06_bootstrap/self/bootstrap_cards.rb +15 -0
- data/tmpsets/set/mod008-06_bootstrap/self/bootstrap_js.rb +13 -0
- data/tmpsets/set/mod008-06_bootstrap/self/bootswatch_shared.rb +38 -0
- data/tmpsets/set/mod008-06_bootstrap/self/smartmenu_css.rb +13 -0
- data/tmpsets/set/mod008-06_bootstrap/self/smartmenu_js.rb +12 -0
- data/tmpsets/set_pattern/100-all.rb +24 -0
- data/tmpsets/set_pattern/101-all_plus.rb +26 -0
- data/tmpsets/set_pattern/102-type.rb +36 -0
- data/tmpsets/set_pattern/103-star.rb +28 -0
- data/tmpsets/set_pattern/104-rstar.rb +30 -0
- data/tmpsets/set_pattern/105-right.rb +33 -0
- data/tmpsets/set_pattern/106-type_plus_right.rb +36 -0
- data/tmpsets/set_pattern/107-self.rb +32 -0
- metadata +306 -107
- data/mod/05_standard/set/all/attach.rb +0 -164
- data/mod/05_standard/spec/set/all/attach_spec.rb +0 -9
@@ -0,0 +1,21 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
2
|
+
class Card; module Set; module Self; module Never; extend Card::Set # ~~~~~~~~~~~ above autogenerated; below pulled from /Users/ethan/dev/wagn/gem/card/mod/05_email/set/self/never.rb ~~~~~~~~~~~
|
3
|
+
include Card::FollowOption
|
4
|
+
|
5
|
+
self.follow_opts :position=>3
|
6
|
+
|
7
|
+
self.follow_test { |follower_id, accounted_ids| false }
|
8
|
+
|
9
|
+
|
10
|
+
def title
|
11
|
+
'Ignoring'
|
12
|
+
end
|
13
|
+
|
14
|
+
def label
|
15
|
+
'ignore'
|
16
|
+
end
|
17
|
+
|
18
|
+
|
19
|
+
|
20
|
+
# ~~~~~~~~~~~ below autogenerated; above pulled from /Users/ethan/dev/wagn/gem/card/mod/05_email/set/self/never.rb ~~~~~~~~~~~
|
21
|
+
end;end;end;end;
|
@@ -0,0 +1,119 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
2
|
+
class Card; module Set; module Type; module EmailTemplate; extend Card::Set # ~~~~~~~~~~~ above autogenerated; below pulled from /Users/ethan/dev/wagn/gem/card/mod/05_email/set/type/email_template.rb ~~~~~~~~~~~
|
3
|
+
|
4
|
+
def clean_html?
|
5
|
+
false
|
6
|
+
end
|
7
|
+
|
8
|
+
def deliver args={}
|
9
|
+
begin
|
10
|
+
mail = format.render_mail(args)
|
11
|
+
mail.deliver
|
12
|
+
rescue Net::SMTPError => exception
|
13
|
+
errors.add :exception, exception.message
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
def process_email_field field, config, args
|
18
|
+
config[field] =
|
19
|
+
if args[field]
|
20
|
+
args[field]
|
21
|
+
elsif field_card = fetch(:trait=>field)
|
22
|
+
# configuration can be anything visible to configurer
|
23
|
+
user = ( args[:follower] and Card.fetch(args[:follower]) ) || field_card.updater
|
24
|
+
Auth.as( user ) do
|
25
|
+
yield(field_card)
|
26
|
+
end
|
27
|
+
else
|
28
|
+
''
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
def process_message_field field, config, args, format, special_args=nil
|
33
|
+
process_email_field( field, config, args ) do |field_card|
|
34
|
+
content_args = args.clone
|
35
|
+
content_args.merge! special_args if special_args
|
36
|
+
field_card.contextual_content args[:context], { :format=>format }, content_args
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
def email_config args={}
|
41
|
+
config = {}
|
42
|
+
args[:context] ||= self
|
43
|
+
|
44
|
+
[:to, :from, :cc, :bcc].each do |field_name|
|
45
|
+
process_email_field( field_name, config, args ) do |field_card|
|
46
|
+
field_card.process_email_addresses args[:context], {:format=>'email_text'}, args
|
47
|
+
end
|
48
|
+
end
|
49
|
+
process_email_field( :attach, config, args ) do |field_card|
|
50
|
+
field_card.extended_item_contents args[:context]
|
51
|
+
end
|
52
|
+
process_message_field :subject, config, args, 'email_text', :content_opts=>{ :chunk_list=>:inclusion_only }
|
53
|
+
process_message_field :text_message, config, args, 'email_text'
|
54
|
+
process_message_field :html_message, config, args, 'email_html'
|
55
|
+
config[:html_message] = Card::Mailer.layout config[:html_message] if config[:html_message].present?
|
56
|
+
|
57
|
+
|
58
|
+
from_name, from_email = (config[:from] =~ /(.*)\<(.*)>/) ? [$1.strip, $2] : [nil, config[:from]]
|
59
|
+
|
60
|
+
if default_from=Card::Mailer.default[:from]
|
61
|
+
config[:from] = from_email ? %["#{from_name || from_email}" <#{default_from}>] : default_from
|
62
|
+
config[:reply_to] ||= config[:from]
|
63
|
+
elsif config[:from].blank?
|
64
|
+
config[:from] = Card[Card::WagnBotID].account.email
|
65
|
+
end
|
66
|
+
config.select {|k,v| v.present? }
|
67
|
+
end
|
68
|
+
|
69
|
+
|
70
|
+
format do
|
71
|
+
view :mail, :perms=>:none do |args|
|
72
|
+
args = card.email_config(args)
|
73
|
+
text_message = args.delete(:text_message)
|
74
|
+
html_message = args.delete(:html_message)
|
75
|
+
attachment_list = args.delete(:attach)
|
76
|
+
alternative = (text_message.present? && html_message.present?)
|
77
|
+
mail = Card::Mailer.new_mail(args) do
|
78
|
+
if alternative
|
79
|
+
if attachment_list and !attachment_list.empty?
|
80
|
+
content_type 'multipart/mixed'
|
81
|
+
part :content_type => 'multipart/alternative' do |copy|
|
82
|
+
copy.part :content_type => 'text/plain' do |plain|
|
83
|
+
plain.body = text_message
|
84
|
+
end
|
85
|
+
copy.part :content_type => 'text/html' do |html|
|
86
|
+
html.body = html_message
|
87
|
+
end
|
88
|
+
end
|
89
|
+
else
|
90
|
+
text_part { body text_message }
|
91
|
+
html_part do
|
92
|
+
content_type 'text/html; charset=UTF-8'
|
93
|
+
body html_message
|
94
|
+
end
|
95
|
+
end
|
96
|
+
elsif html_message.present?
|
97
|
+
content_type 'text/html; charset=UTF-8'
|
98
|
+
body html_message
|
99
|
+
else
|
100
|
+
content_type 'text/plain; charset=UTF-8'
|
101
|
+
text_part { body text_message }
|
102
|
+
end
|
103
|
+
|
104
|
+
if attachment_list
|
105
|
+
attachment_list.each_with_index do |cardname, i|
|
106
|
+
if c = Card[ cardname ] and c.respond_to?(:attachment)
|
107
|
+
add_file :filename => "attachment-#{i + 1}.#{c.attachment.extension}", :content => File.read( c.attachment.path )
|
108
|
+
end
|
109
|
+
end
|
110
|
+
end
|
111
|
+
end #TODO add error handling
|
112
|
+
mail
|
113
|
+
end
|
114
|
+
|
115
|
+
end
|
116
|
+
|
117
|
+
|
118
|
+
# ~~~~~~~~~~~ below autogenerated; above pulled from /Users/ethan/dev/wagn/gem/card/mod/05_email/set/type/email_template.rb ~~~~~~~~~~~
|
119
|
+
end;end;end;end;
|
@@ -0,0 +1,182 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
2
|
+
class Card; module Set; module TypePlusRight; module User; module Follow; extend Card::Set # ~~~~~~~~~~~ above autogenerated; below pulled from /Users/ethan/dev/wagn/gem/card/mod/05_email/set/type_plus_right/user/follow.rb ~~~~~~~~~~~
|
3
|
+
|
4
|
+
include Card::Set::Type::Pointer
|
5
|
+
|
6
|
+
def raw_content
|
7
|
+
@raw_content ||= if left
|
8
|
+
items = if left.type_id == Card::UserID
|
9
|
+
user = left
|
10
|
+
follow_rules = Card.user_rule_cards left.name, 'follow'
|
11
|
+
follow_rules.map {|card| "[[#{card.name}]]" }
|
12
|
+
end.join "\n"
|
13
|
+
else
|
14
|
+
''
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
def virtual?; true end
|
19
|
+
|
20
|
+
|
21
|
+
|
22
|
+
format() { include Card::Set::Type::Pointer::Format }
|
23
|
+
|
24
|
+
|
25
|
+
format :html do
|
26
|
+
include Card::Set::Type::Pointer::HtmlFormat
|
27
|
+
|
28
|
+
|
29
|
+
view :closed_content do |args|
|
30
|
+
''
|
31
|
+
end
|
32
|
+
|
33
|
+
|
34
|
+
view :core do |args|
|
35
|
+
%{
|
36
|
+
<div role="tabpanel">
|
37
|
+
<ul class="nav nav-tabs" role="tablist" id="myTab">
|
38
|
+
<li role="presentation" class="active"><a href="#following" aria-controls="following" role="tab" data-toggle="tab">Follow</a></li>
|
39
|
+
<li role="presentation"><a href="#ignoring" aria-controls="ignoring" role="tab" data-toggle="tab">Ignore</a></li>
|
40
|
+
</ul>
|
41
|
+
|
42
|
+
<div class="tab-content">
|
43
|
+
<div role="tabpanel" class="tab-pane active" id="following">#{render_following_list args}</div>
|
44
|
+
<div role="tabpanel" class="tab-pane" id="ignoring">#{render_ignoring_list}</div>
|
45
|
+
</div>
|
46
|
+
</div>
|
47
|
+
}
|
48
|
+
end
|
49
|
+
|
50
|
+
|
51
|
+
def followed_by_option
|
52
|
+
hash = Hash.new { |h,k| h[k] = [] }
|
53
|
+
card.item_cards.each do |follow_rule|
|
54
|
+
follow_rule.item_cards.each do |follow_option|
|
55
|
+
hash[follow_option.codename.to_sym] << follow_rule
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
59
|
+
|
60
|
+
def each_suggestion
|
61
|
+
if (suggestions = Card["follow suggestions"])
|
62
|
+
suggestions.item_names.each do |sug|
|
63
|
+
if ((set_card = Card.fetch sug.to_name.left) && set_card.type_code == :set)
|
64
|
+
option_card = Card.fetch(sug.to_name.right) || Card[sug.to_name.right.to_sym]
|
65
|
+
option = if option_card.follow_option?
|
66
|
+
option_card.name
|
67
|
+
else
|
68
|
+
'*always'
|
69
|
+
end
|
70
|
+
yield(set_card, option)
|
71
|
+
elsif ((set_card = Card.fetch sug) && set_card.type_code == :set)
|
72
|
+
yield(set_card, '*always')
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
78
|
+
# returns hashes with existing and suggested follow options
|
79
|
+
# structure:
|
80
|
+
# set_pattern_class => [ {:card=>rule_card, :options=>['*always', '*created'] },.... ]
|
81
|
+
def followed_by_set
|
82
|
+
res = Hash.new { |h,k| h[k] = [] }
|
83
|
+
never = Card[:never].name
|
84
|
+
card.item_cards.each do |follow_rule|
|
85
|
+
options = follow_rule.item_names.reject { |item| item == never}
|
86
|
+
res[follow_rule.rule_set.subclass_for_set] << { :card=>follow_rule, :options=>options }
|
87
|
+
end
|
88
|
+
|
89
|
+
if Auth.signed_in? && Auth.current_id == card.left.id
|
90
|
+
each_suggestion do |set_card, option|
|
91
|
+
suggested_rule_name = set_card.follow_rule_name(card.trunk)
|
92
|
+
if (rule = res[set_card.subclass_for_set].find { |rule| rule[:card].name == suggested_rule_name })
|
93
|
+
if !rule[:options].include? option
|
94
|
+
rule[:options] << option
|
95
|
+
end
|
96
|
+
else
|
97
|
+
rule_card = Card.new(:name=>suggested_rule_name)
|
98
|
+
res[set_card.subclass_for_set] << {:card=>rule_card, :options=>[option]}
|
99
|
+
end
|
100
|
+
end
|
101
|
+
end
|
102
|
+
res
|
103
|
+
end
|
104
|
+
|
105
|
+
|
106
|
+
view :following_list do |args|
|
107
|
+
if !Auth.signed_in? || Auth.current_id != card.left.id
|
108
|
+
hide_buttons = [:delete_follow_rule_button, :add_follow_rule_button]
|
109
|
+
end
|
110
|
+
|
111
|
+
sets = followed_by_set
|
112
|
+
wrap_with :div, :class=>'pointer-list-editor' do
|
113
|
+
wrap_with :ul, :class=>'delete-list list-group' do
|
114
|
+
|
115
|
+
Card.set_patterns.select{|p| sets[p]}.reverse.map do |set_pattern|
|
116
|
+
sets[set_pattern].map do |rule|
|
117
|
+
rule[:options].map do |option|
|
118
|
+
|
119
|
+
content_tag :li, :class=>'list-group-item' do
|
120
|
+
subformat(rule[:card]).render_follow_item :condition=>option, :hide=>hide_buttons
|
121
|
+
end
|
122
|
+
|
123
|
+
end.join("\n")
|
124
|
+
end.join("\n")
|
125
|
+
end.join("\n")
|
126
|
+
|
127
|
+
end
|
128
|
+
end
|
129
|
+
end
|
130
|
+
|
131
|
+
|
132
|
+
view :ignoring_list do |args|
|
133
|
+
ignore_list = []
|
134
|
+
card.item_cards.each do |follow_rule|
|
135
|
+
follow_rule.item_cards.each do |follow_option|
|
136
|
+
if follow_option.codename.to_sym == :never
|
137
|
+
ignore_list << follow_rule
|
138
|
+
end
|
139
|
+
end
|
140
|
+
end
|
141
|
+
if !Auth.signed_in? || Auth.current_id != card.left.id
|
142
|
+
hide_buttons = [:delete_follow_rule_button, :add_follow_rule_button]
|
143
|
+
end
|
144
|
+
never = Card[:never].name
|
145
|
+
wrap_with :div, :class=>'pointer-list-editor' do
|
146
|
+
wrap_with :ul, :class=>'delete-list list-group' do
|
147
|
+
|
148
|
+
ignore_list.map do |rule_card|
|
149
|
+
content_tag :li, :class=>'list-group-item' do
|
150
|
+
subformat(rule_card).render_follow_item :condition=>never, :hide=>hide_buttons
|
151
|
+
end
|
152
|
+
end.join "\n"
|
153
|
+
|
154
|
+
end
|
155
|
+
end
|
156
|
+
end
|
157
|
+
|
158
|
+
view :pointer_items, :tags=>:unknown_ok do |args|
|
159
|
+
super(args.merge(:item=>:link))
|
160
|
+
end
|
161
|
+
|
162
|
+
view :errors, :perms=>:none do |args|
|
163
|
+
if card.errors.any?
|
164
|
+
if card.errors.find { |attrib,msg| attrib == :permission_denied }
|
165
|
+
save_interrupted_action(request.env['REQUEST_URI'])
|
166
|
+
title = "Problems with #{card.name}"
|
167
|
+
frame args.merge(:panel_class=>"panel panel-warning", :title=>title, :hide=>'menu' ) do
|
168
|
+
"Please #{ link_to 'sign in', card_url(':signin') }" #" #{to_task}"
|
169
|
+
end
|
170
|
+
else
|
171
|
+
super(args)
|
172
|
+
end
|
173
|
+
end
|
174
|
+
end
|
175
|
+
|
176
|
+
end
|
177
|
+
|
178
|
+
format(:css ) { include Card::Set::Type::Pointer::CssFormat }
|
179
|
+
|
180
|
+
|
181
|
+
# ~~~~~~~~~~~ below autogenerated; above pulled from /Users/ethan/dev/wagn/gem/card/mod/05_email/set/type_plus_right/user/follow.rb ~~~~~~~~~~~
|
182
|
+
end;end;end;end;end;
|
@@ -0,0 +1,91 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
2
|
+
class Card; module Set; module Abstract; module Attachment; extend Card::Set # ~~~~~~~~~~~ above autogenerated; below pulled from /Users/ethan/dev/wagn/gem/card/mod/05_standard/set/abstract/attachment.rb ~~~~~~~~~~~
|
3
|
+
require 'carrier_wave/cardmount'
|
4
|
+
def self.included host_class
|
5
|
+
host_class.extend CarrierWave::CardMount
|
6
|
+
end
|
7
|
+
|
8
|
+
|
9
|
+
event :write_identifier, :after=>:assign_action do
|
10
|
+
self.content = attachment.db_content
|
11
|
+
end
|
12
|
+
|
13
|
+
event :save_original_filename, :before=>:finalize_action do
|
14
|
+
if @current_action
|
15
|
+
@current_action.update_attributes! :comment=>original_filename
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
event :move_file_to_store_dir, :after=>:store, :on=>:create do
|
20
|
+
if ::File.exist? tmp_store_dir
|
21
|
+
if ::File.exist? store_dir
|
22
|
+
FileUtils.rm_rf store_dir
|
23
|
+
end
|
24
|
+
FileUtils.mv tmp_store_dir, store_dir
|
25
|
+
end
|
26
|
+
if !(content =~ /^[:~]/)
|
27
|
+
update_column(:db_content,attachment.db_content)
|
28
|
+
expire
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
def item_names(args={}) # needed for flexmail attachments. hacky.
|
33
|
+
[self.cardname]
|
34
|
+
end
|
35
|
+
|
36
|
+
def original_filename
|
37
|
+
attachment.original_filename
|
38
|
+
end
|
39
|
+
|
40
|
+
|
41
|
+
def assign_set_specific_attributes
|
42
|
+
if @set_specific && @set_specific.present?
|
43
|
+
self.content = nil
|
44
|
+
end
|
45
|
+
super
|
46
|
+
end
|
47
|
+
|
48
|
+
|
49
|
+
def symlink_to(prior_action_id) # create filesystem links to files from prior action
|
50
|
+
if prior_action_id != last_action_id
|
51
|
+
save_action_id = selected_action_id
|
52
|
+
links = {}
|
53
|
+
|
54
|
+
self.selected_action_id = prior_action_id
|
55
|
+
attachment.versions.each do |name, version|
|
56
|
+
links[name] = version.store_path
|
57
|
+
end
|
58
|
+
original = attachment.store_path
|
59
|
+
|
60
|
+
self.selected_action_id = last_action_id
|
61
|
+
attachment.versions.each do |name, version|
|
62
|
+
::File.symlink links[name], version.store_path
|
63
|
+
end
|
64
|
+
::File.symlink original, attachment.store_path
|
65
|
+
|
66
|
+
self.selected_action_id = save_action_id
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|
70
|
+
def attachment_format(ext)
|
71
|
+
if ext.present? && attachment && original_ext=attachment.extension
|
72
|
+
if['file', original_ext].member? ext
|
73
|
+
original_ext
|
74
|
+
elsif exts = MIME::Types[attachment.content_type]
|
75
|
+
if exts.find {|mt| mt.extensions.member? ext }
|
76
|
+
ext
|
77
|
+
else
|
78
|
+
exts[0].extensions[0]
|
79
|
+
end
|
80
|
+
end
|
81
|
+
end
|
82
|
+
rescue => e
|
83
|
+
Rails.logger.info "attachment_format issue: #{e.message}"
|
84
|
+
nil
|
85
|
+
end
|
86
|
+
|
87
|
+
|
88
|
+
|
89
|
+
|
90
|
+
# ~~~~~~~~~~~ below autogenerated; above pulled from /Users/ethan/dev/wagn/gem/card/mod/05_standard/set/abstract/attachment.rb ~~~~~~~~~~~
|
91
|
+
end;end;end;end;
|
@@ -0,0 +1,73 @@
|
|
1
|
+
# -*- encoding : utf-8 -*-
|
2
|
+
class Card; module Set; module All; module Account; extend Card::Set # ~~~~~~~~~~~ above autogenerated; below pulled from /Users/ethan/dev/wagn/gem/card/mod/05_standard/set/all/account.rb ~~~~~~~~~~~
|
3
|
+
module ClassMethods
|
4
|
+
def default_accounted_type_id
|
5
|
+
Card::UserID
|
6
|
+
end
|
7
|
+
end
|
8
|
+
|
9
|
+
def account
|
10
|
+
fetch :trait=>:account
|
11
|
+
end
|
12
|
+
|
13
|
+
def accountable?
|
14
|
+
Card.toggle( rule :accountable )
|
15
|
+
end
|
16
|
+
|
17
|
+
def parties
|
18
|
+
@parties ||= (all_roles << self.id).flatten.reject(&:blank?)
|
19
|
+
end
|
20
|
+
|
21
|
+
def among? ok_ids
|
22
|
+
ok_ids.each do |ok_id|
|
23
|
+
return true if parties.member? ok_id
|
24
|
+
end
|
25
|
+
ok_ids.member? Card::AnyoneID
|
26
|
+
end
|
27
|
+
|
28
|
+
def is_own_account?
|
29
|
+
# card is +*account card of signed_in user.
|
30
|
+
cardname.part_names[0].key == Auth.as_card.key and
|
31
|
+
cardname.part_names[1].key == Card[:account].key
|
32
|
+
end
|
33
|
+
|
34
|
+
def read_rules
|
35
|
+
@read_rules ||= begin
|
36
|
+
rule_ids = []
|
37
|
+
unless id==Card::WagnBotID # always_ok, so not needed
|
38
|
+
( [ Card::AnyoneID ] + parties ).each do |party_id|
|
39
|
+
if rule_ids_for_party = self.class.read_rule_cache[ party_id ]
|
40
|
+
rule_ids += rule_ids_for_party
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
rule_ids
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
def all_roles
|
49
|
+
@all_roles ||=
|
50
|
+
if id == Card::AnonymousID
|
51
|
+
[]
|
52
|
+
else
|
53
|
+
Auth.as_bot do
|
54
|
+
role_trait = fetch :trait=>:roles
|
55
|
+
[ Card::AnyoneSignedInID ] + ( role_trait ? role_trait.item_ids : [] )
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
59
|
+
|
60
|
+
|
61
|
+
event :generate_token do
|
62
|
+
Digest::SHA1.hexdigest "--#{Time.now.to_f}--#{rand 10}--"
|
63
|
+
end
|
64
|
+
|
65
|
+
event :set_stamper, :before=>:approve do
|
66
|
+
self.updater_id = Auth.current_id
|
67
|
+
self.creator_id = self.updater_id if new_card?
|
68
|
+
end
|
69
|
+
|
70
|
+
|
71
|
+
|
72
|
+
# ~~~~~~~~~~~ below autogenerated; above pulled from /Users/ethan/dev/wagn/gem/card/mod/05_standard/set/all/account.rb ~~~~~~~~~~~
|
73
|
+
end;end;end;end;
|