dune-dashboard 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.bowerrc +3 -0
- data/.gitignore +22 -0
- data/.rspec +2 -0
- data/.travis.yml +13 -0
- data/CHANGELOG.md +6 -0
- data/Gemfile +12 -0
- data/Gemfile.lock +392 -0
- data/LICENSE.txt +22 -0
- data/README.md +58 -0
- data/Rakefile +23 -0
- data/app/assets/images/dune/dashboard/logo@2x.png +0 -0
- data/app/assets/javascripts/adapters/channel_adapter.coffee +1 -0
- data/app/assets/javascripts/adapters/form_data.coffee +26 -0
- data/app/assets/javascripts/adapters/press_asset_adapter.coffee +1 -0
- data/app/assets/javascripts/configs.coffee +10 -0
- data/app/assets/javascripts/controllers/.gitkeep +0 -0
- data/app/assets/javascripts/controllers/channels.coffee +40 -0
- data/app/assets/javascripts/controllers/contributions.coffee +26 -0
- data/app/assets/javascripts/controllers/press_assets.coffee +24 -0
- data/app/assets/javascripts/controllers/projects.coffee +36 -0
- data/app/assets/javascripts/controllers/sessions.coffee +2 -0
- data/app/assets/javascripts/controllers/tags.coffee +24 -0
- data/app/assets/javascripts/controllers/users.coffee +8 -0
- data/app/assets/javascripts/dashboard.coffee +5 -0
- data/app/assets/javascripts/dune-dashboard-application.js +16 -0
- data/app/assets/javascripts/dune-dashboard-libs.js +25 -0
- data/app/assets/javascripts/dune-dashboard-templates.js +1 -0
- data/app/assets/javascripts/helpers/daterangepicker.coffee +1 -0
- data/app/assets/javascripts/helpers/format-date.coffee +5 -0
- data/app/assets/javascripts/helpers/loading.coffee +14 -0
- data/app/assets/javascripts/helpers/number-to-currency.coffee +5 -0
- data/app/assets/javascripts/helpers/pagination.coffee +1 -0
- data/app/assets/javascripts/helpers/show-boolean.coffee +5 -0
- data/app/assets/javascripts/i18n/translations_en.js +165 -0
- data/app/assets/javascripts/initializers/authentication.coffee +50 -0
- data/app/assets/javascripts/mixins/modal-controller.coffee +7 -0
- data/app/assets/javascripts/mixins/modal-view.coffee +15 -0
- data/app/assets/javascripts/mixins/paginable.coffee +25 -0
- data/app/assets/javascripts/mixins/searchable.coffee +58 -0
- data/app/assets/javascripts/models/.gitkeep +0 -0
- data/app/assets/javascripts/models/channel.coffee +25 -0
- data/app/assets/javascripts/models/contributions.coffee +15 -0
- data/app/assets/javascripts/models/press_asset.coffee +5 -0
- data/app/assets/javascripts/models/project.coffee +16 -0
- data/app/assets/javascripts/models/reward.coffee +4 -0
- data/app/assets/javascripts/models/tag.coffee +4 -0
- data/app/assets/javascripts/models/user.coffee +13 -0
- data/app/assets/javascripts/router.coffee +36 -0
- data/app/assets/javascripts/routes/.gitkeep +0 -0
- data/app/assets/javascripts/routes/application.coffee +35 -0
- data/app/assets/javascripts/routes/channels-edit.coffee +4 -0
- data/app/assets/javascripts/routes/channels-new.coffee +4 -0
- data/app/assets/javascripts/routes/channels.coffee +21 -0
- data/app/assets/javascripts/routes/contributions.coffee +29 -0
- data/app/assets/javascripts/routes/index.coffee +4 -0
- data/app/assets/javascripts/routes/press_assets-edit.coffee +4 -0
- data/app/assets/javascripts/routes/press_assets-new.coffee +5 -0
- data/app/assets/javascripts/routes/press_assets.coffee +13 -0
- data/app/assets/javascripts/routes/projects.coffee +23 -0
- data/app/assets/javascripts/routes/sessions.coffee +3 -0
- data/app/assets/javascripts/routes/tags-edit.coffee +4 -0
- data/app/assets/javascripts/routes/tags-new.coffee +5 -0
- data/app/assets/javascripts/routes/tags.coffee +15 -0
- data/app/assets/javascripts/routes/users.coffee +17 -0
- data/app/assets/javascripts/serializers/channel.coffee +10 -0
- data/app/assets/javascripts/serializers/file.coffee +6 -0
- data/app/assets/javascripts/serializers/object.coffee +6 -0
- data/app/assets/javascripts/serializers/project.coffee +4 -0
- data/app/assets/javascripts/store.coffee +5 -0
- data/app/assets/javascripts/templates/.gitkeep +0 -0
- data/app/assets/javascripts/templates/channels/_form.emblem +256 -0
- data/app/assets/javascripts/templates/channels/edit.emblem +1 -0
- data/app/assets/javascripts/templates/channels/index.emblem +66 -0
- data/app/assets/javascripts/templates/channels/new.emblem +1 -0
- data/app/assets/javascripts/templates/channels/search-form.emblem +13 -0
- data/app/assets/javascripts/templates/contributions/index.emblem +111 -0
- data/app/assets/javascripts/templates/contributions/search-form.emblem +27 -0
- data/app/assets/javascripts/templates/contributions/show.emblem +79 -0
- data/app/assets/javascripts/templates/daterangepicker.emblem +5 -0
- data/app/assets/javascripts/templates/layouts/application.emblem +19 -0
- data/app/assets/javascripts/templates/layouts/header.emblem +25 -0
- data/app/assets/javascripts/templates/layouts/sidebar.emblem +32 -0
- data/app/assets/javascripts/templates/pagination.emblem +10 -0
- data/app/assets/javascripts/templates/press_assets/_form.emblem +33 -0
- data/app/assets/javascripts/templates/press_assets/edit.emblem +1 -0
- data/app/assets/javascripts/templates/press_assets/index.emblem +45 -0
- data/app/assets/javascripts/templates/press_assets/new.emblem +1 -0
- data/app/assets/javascripts/templates/projects/index.emblem +119 -0
- data/app/assets/javascripts/templates/projects/search-form.emblem +19 -0
- data/app/assets/javascripts/templates/search-tab.emblem +6 -0
- data/app/assets/javascripts/templates/sessions/new.emblem +17 -0
- data/app/assets/javascripts/templates/tags/_form.emblem +24 -0
- data/app/assets/javascripts/templates/tags/edit.emblem +1 -0
- data/app/assets/javascripts/templates/tags/index.emblem +46 -0
- data/app/assets/javascripts/templates/tags/new.emblem +1 -0
- data/app/assets/javascripts/templates/users/index.emblem +51 -0
- data/app/assets/javascripts/templates/users/search-form.emblem +13 -0
- data/app/assets/javascripts/views/auto-save-checkbox.coffee +14 -0
- data/app/assets/javascripts/views/contributions/show.coffee +1 -0
- data/app/assets/javascripts/views/daterangepicker.coffee +60 -0
- data/app/assets/javascripts/views/file.coffee +7 -0
- data/app/assets/javascripts/views/layouts/header.coffee +23 -0
- data/app/assets/javascripts/views/layouts/sidebar.coffee +6 -0
- data/app/assets/javascripts/views/page-title.coffee +45 -0
- data/app/assets/javascripts/views/pagination.coffee +51 -0
- data/app/assets/javascripts/views/projects/index.coffee +5 -0
- data/app/assets/javascripts/views/search-tab.coffee +24 -0
- data/app/assets/stylesheets/core/core.sass +299 -0
- data/app/assets/stylesheets/core/mixins.sass +83 -0
- data/app/assets/stylesheets/core/settings.sass +75 -0
- data/app/assets/stylesheets/dune-dashboard-application.sass +12 -0
- data/app/assets/stylesheets/modules/alerts.sass +21 -0
- data/app/assets/stylesheets/modules/avatar.sass +13 -0
- data/app/assets/stylesheets/modules/boxes.sass +274 -0
- data/app/assets/stylesheets/modules/buttons.sass +160 -0
- data/app/assets/stylesheets/modules/dl-details.sass +13 -0
- data/app/assets/stylesheets/modules/forms.sass +53 -0
- data/app/assets/stylesheets/modules/generic.sass +9 -0
- data/app/assets/stylesheets/modules/header.sass +153 -0
- data/app/assets/stylesheets/modules/labels.sass +3 -0
- data/app/assets/stylesheets/modules/navs.sass +98 -0
- data/app/assets/stylesheets/modules/pagination.sass +19 -0
- data/app/assets/stylesheets/modules/sidebar.sass +147 -0
- data/app/assets/stylesheets/modules/small-box.sass +78 -0
- data/app/assets/stylesheets/pages/login.sass +42 -0
- data/app/controllers/dune/dashboard/ember_controller.rb +7 -0
- data/app/views/layouts/dune/dashboard/application.html.erb +15 -0
- data/bower.json +28 -0
- data/config/ember-i18n.yml +2 -0
- data/config/ember_locales/channels.en.yml +49 -0
- data/config/ember_locales/contributions.en.yml +42 -0
- data/config/ember_locales/en.yml +1 -0
- data/config/ember_locales/layouts.en.yml +16 -0
- data/config/ember_locales/press_assets.en.yml +14 -0
- data/config/ember_locales/projects.en.yml +33 -0
- data/config/ember_locales/sessions.en.yml +11 -0
- data/config/ember_locales/tags.en.yml +12 -0
- data/config/ember_locales/titles.en.yml +22 -0
- data/config/ember_locales/users.en.yml +12 -0
- data/config/ember_locales/words.en.yml +12 -0
- data/config/routes.rb +4 -0
- data/dune-dashboard.gemspec +28 -0
- data/lib/dune/dashboard.rb +11 -0
- data/lib/dune/dashboard/engine.rb +12 -0
- data/lib/dune/dashboard/i18n.rb +108 -0
- data/lib/dune/dashboard/version.rb +5 -0
- data/spec/dummy/README.rdoc +28 -0
- data/spec/dummy/Rakefile +6 -0
- data/spec/dummy/app/assets/images/.keep +0 -0
- data/spec/dummy/app/assets/javascripts/application.js +13 -0
- data/spec/dummy/app/assets/stylesheets/application.css +13 -0
- data/spec/dummy/app/controllers/application_controller.rb +5 -0
- data/spec/dummy/app/controllers/concerns/.keep +0 -0
- data/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/spec/dummy/app/mailers/.keep +0 -0
- data/spec/dummy/app/models/.keep +0 -0
- data/spec/dummy/app/models/concerns/.keep +0 -0
- data/spec/dummy/app/views/layouts/application.html.erb +14 -0
- data/spec/dummy/bin/bundle +3 -0
- data/spec/dummy/bin/rails +4 -0
- data/spec/dummy/bin/rake +4 -0
- data/spec/dummy/config.ru +4 -0
- data/spec/dummy/config/application.rb +30 -0
- data/spec/dummy/config/boot.rb +5 -0
- data/spec/dummy/config/environment.rb +5 -0
- data/spec/dummy/config/environments/development.rb +29 -0
- data/spec/dummy/config/environments/production.rb +80 -0
- data/spec/dummy/config/environments/test.rb +38 -0
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy/config/initializers/filter_parameter_logging.rb +4 -0
- data/spec/dummy/config/initializers/inflections.rb +16 -0
- data/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/spec/dummy/config/initializers/secret_token.rb +12 -0
- data/spec/dummy/config/initializers/session_store.rb +3 -0
- data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/spec/dummy/config/locales/en.yml +23 -0
- data/spec/dummy/config/routes.rb +3 -0
- data/spec/dummy/lib/assets/.keep +0 -0
- data/spec/dummy/log/.keep +0 -0
- data/spec/dummy/public/404.html +58 -0
- data/spec/dummy/public/422.html +58 -0
- data/spec/dummy/public/500.html +57 -0
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/javascripts/controllers/channels_spec.coffee +16 -0
- data/spec/javascripts/controllers/press_assets_spec.coffee +5 -0
- data/spec/javascripts/controllers/projects_spec.coffee +16 -0
- data/spec/javascripts/controllers/users_spec.coffee +16 -0
- data/spec/javascripts/fixtures/channels.coffee +49 -0
- data/spec/javascripts/fixtures/contributions.coffee +46 -0
- data/spec/javascripts/fixtures/press_assets.coffee +15 -0
- data/spec/javascripts/fixtures/projects.coffee +108 -0
- data/spec/javascripts/fixtures/tags.coffee +15 -0
- data/spec/javascripts/fixtures/users.coffee +26 -0
- data/spec/javascripts/helpers/auththentication.coffee +11 -0
- data/spec/javascripts/integration/channels_spec.coffee +109 -0
- data/spec/javascripts/integration/contributions_spec.coffee +108 -0
- data/spec/javascripts/integration/press_assets_spec.coffee +66 -0
- data/spec/javascripts/integration/projects_spec.coffee +110 -0
- data/spec/javascripts/integration/sessions_spec.coffee +71 -0
- data/spec/javascripts/integration/tags_spec.coffee +65 -0
- data/spec/javascripts/integration/users_spec.coffee +108 -0
- data/spec/javascripts/models/channel_spec.coffee +4 -0
- data/spec/javascripts/models/contribution_spec.coffee +4 -0
- data/spec/javascripts/models/press_asset_spec.coffee +5 -0
- data/spec/javascripts/models/project_spec.coffee +4 -0
- data/spec/javascripts/models/reward_spec.coffee +4 -0
- data/spec/javascripts/models/tag_spec.coffee +4 -0
- data/spec/javascripts/models/user_spec.coffee +4 -0
- data/spec/javascripts/spec_helper.coffee +56 -0
- data/spec/javascripts/support/jquery.mockjax.js +598 -0
- data/spec/teaspoon_env.rb +183 -0
- data/vendor/assets/components/cldr/.bower.json +14 -0
- data/vendor/assets/components/cldr/README.md +47 -0
- data/vendor/assets/components/cldr/plurals.js +240 -0
- data/vendor/assets/components/ember-i18n/.bower.json +46 -0
- data/vendor/assets/components/ember-i18n/CONTRIBUTING.md +13 -0
- data/vendor/assets/components/ember-i18n/Changelog.md +82 -0
- data/vendor/assets/components/ember-i18n/LICENSE +10 -0
- data/vendor/assets/components/ember-i18n/README.md +148 -0
- data/vendor/assets/components/ember-i18n/VERSION +1 -0
- data/vendor/assets/components/ember-i18n/bower.json +34 -0
- data/vendor/assets/components/ember-i18n/lib/i18n.js +215 -0
- data/vendor/assets/components/ember-i18n/package.json +27 -0
- data/vendor/assets/components/ember-i18n/script/buildSuite.js +34 -0
- data/vendor/assets/components/ember-i18n/script/fetch_vendor.js +66 -0
- data/vendor/assets/components/ember-i18n/script/run.js +24 -0
- data/vendor/assets/components/ember-simple-auth/.bower.json +31 -0
- data/vendor/assets/components/ember-simple-auth/LICENSE +20 -0
- data/vendor/assets/components/ember-simple-auth/README.md +15 -0
- data/vendor/assets/components/ember-simple-auth/bower.json +21 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth-cookie-store.amd.js +220 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth-cookie-store.js +284 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth-devise.amd.js +243 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth-devise.js +312 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth-oauth2.amd.js +386 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth-oauth2.js +455 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth-testing.amd.js +79 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth-testing.js +137 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth-torii.amd.js +142 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth-torii.js +199 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth.amd.js +1450 -0
- data/vendor/assets/components/ember-simple-auth/simple-auth.js +1548 -0
- data/vendor/assets/components/ember/.bower.json +21 -0
- data/vendor/assets/components/ember/.gitignore +5 -0
- data/vendor/assets/components/ember/Makefile +9 -0
- data/vendor/assets/components/ember/README.md +12 -0
- data/vendor/assets/components/ember/bower.json +11 -0
- data/vendor/assets/components/ember/component.json +13 -0
- data/vendor/assets/components/ember/composer.json +27 -0
- data/vendor/assets/components/ember/ember-template-compiler.js +336 -0
- data/vendor/assets/components/ember/ember.js +46762 -0
- data/vendor/assets/components/ember/ember.min.js +20 -0
- data/vendor/assets/components/ember/ember.prod.js +46319 -0
- data/vendor/assets/components/ember/package.json +11 -0
- data/vendor/assets/components/handlebars/.bower.json +16 -0
- data/vendor/assets/components/handlebars/.gitignore +2 -0
- data/vendor/assets/components/handlebars/README.md +11 -0
- data/vendor/assets/components/handlebars/bower.json +6 -0
- data/vendor/assets/components/handlebars/component.json +9 -0
- data/vendor/assets/components/handlebars/composer.json +35 -0
- data/vendor/assets/components/handlebars/handlebars-source.gemspec +21 -0
- data/vendor/assets/components/handlebars/handlebars.amd.js +2719 -0
- data/vendor/assets/components/handlebars/handlebars.amd.min.js +28 -0
- data/vendor/assets/components/handlebars/handlebars.js +2746 -0
- data/vendor/assets/components/handlebars/handlebars.js.nuspec +17 -0
- data/vendor/assets/components/handlebars/handlebars.min.js +28 -0
- data/vendor/assets/components/handlebars/handlebars.runtime.amd.js +515 -0
- data/vendor/assets/components/handlebars/handlebars.runtime.amd.min.js +27 -0
- data/vendor/assets/components/handlebars/handlebars.runtime.js +530 -0
- data/vendor/assets/components/handlebars/handlebars.runtime.min.js +27 -0
- data/vendor/assets/components/handlebars/lib/handlebars/source.rb +11 -0
- data/vendor/assets/components/jquery/.bower.json +37 -0
- data/vendor/assets/components/jquery/MIT-LICENSE.txt +21 -0
- data/vendor/assets/components/jquery/bower.json +27 -0
- data/vendor/assets/components/jquery/dist/jquery.js +9111 -0
- data/vendor/assets/components/jquery/dist/jquery.min.js +5 -0
- data/vendor/assets/components/jquery/dist/jquery.min.map +1 -0
- data/vendor/assets/components/jquery/src/ajax.js +806 -0
- data/vendor/assets/components/jquery/src/ajax/jsonp.js +89 -0
- data/vendor/assets/components/jquery/src/ajax/load.js +75 -0
- data/vendor/assets/components/jquery/src/ajax/parseJSON.js +13 -0
- data/vendor/assets/components/jquery/src/ajax/parseXML.js +28 -0
- data/vendor/assets/components/jquery/src/ajax/script.js +64 -0
- data/vendor/assets/components/jquery/src/ajax/var/nonce.js +5 -0
- data/vendor/assets/components/jquery/src/ajax/var/rquery.js +3 -0
- data/vendor/assets/components/jquery/src/ajax/xhr.js +130 -0
- data/vendor/assets/components/jquery/src/attributes.js +11 -0
- data/vendor/assets/components/jquery/src/attributes/attr.js +143 -0
- data/vendor/assets/components/jquery/src/attributes/classes.js +158 -0
- data/vendor/assets/components/jquery/src/attributes/prop.js +96 -0
- data/vendor/assets/components/jquery/src/attributes/support.js +35 -0
- data/vendor/assets/components/jquery/src/attributes/val.js +153 -0
- data/vendor/assets/components/jquery/src/callbacks.js +205 -0
- data/vendor/assets/components/jquery/src/core.js +500 -0
- data/vendor/assets/components/jquery/src/core/access.js +60 -0
- data/vendor/assets/components/jquery/src/core/init.js +123 -0
- data/vendor/assets/components/jquery/src/core/parseHTML.js +39 -0
- data/vendor/assets/components/jquery/src/core/ready.js +96 -0
- data/vendor/assets/components/jquery/src/core/var/rsingleTag.js +4 -0
- data/vendor/assets/components/jquery/src/css.js +455 -0
- data/vendor/assets/components/jquery/src/css/addGetHookIf.js +24 -0
- data/vendor/assets/components/jquery/src/css/curCSS.js +57 -0
- data/vendor/assets/components/jquery/src/css/defaultDisplay.js +69 -0
- data/vendor/assets/components/jquery/src/css/hiddenVisibleSelectors.js +15 -0
- data/vendor/assets/components/jquery/src/css/support.js +83 -0
- data/vendor/assets/components/jquery/src/css/swap.js +28 -0
- data/vendor/assets/components/jquery/src/css/var/cssExpand.js +3 -0
- data/vendor/assets/components/jquery/src/css/var/getStyles.js +5 -0
- data/vendor/assets/components/jquery/src/css/var/isHidden.js +13 -0
- data/vendor/assets/components/jquery/src/css/var/rmargin.js +3 -0
- data/vendor/assets/components/jquery/src/css/var/rnumnonpx.js +5 -0
- data/vendor/assets/components/jquery/src/data.js +175 -0
- data/vendor/assets/components/jquery/src/data/Data.js +181 -0
- data/vendor/assets/components/jquery/src/data/accepts.js +20 -0
- data/vendor/assets/components/jquery/src/data/var/data_priv.js +5 -0
- data/vendor/assets/components/jquery/src/data/var/data_user.js +5 -0
- data/vendor/assets/components/jquery/src/deferred.js +149 -0
- data/vendor/assets/components/jquery/src/deprecated.js +13 -0
- data/vendor/assets/components/jquery/src/dimensions.js +50 -0
- data/vendor/assets/components/jquery/src/effects.js +642 -0
- data/vendor/assets/components/jquery/src/effects/Tween.js +114 -0
- data/vendor/assets/components/jquery/src/effects/animatedSelector.js +13 -0
- data/vendor/assets/components/jquery/src/event.js +859 -0
- data/vendor/assets/components/jquery/src/event/alias.js +39 -0
- data/vendor/assets/components/jquery/src/event/support.js +9 -0
- data/vendor/assets/components/jquery/src/exports/amd.js +18 -0
- data/vendor/assets/components/jquery/src/exports/global.js +32 -0
- data/vendor/assets/components/jquery/src/intro.js +44 -0
- data/vendor/assets/components/jquery/src/jquery.js +36 -0
- data/vendor/assets/components/jquery/src/manipulation.js +583 -0
- data/vendor/assets/components/jquery/src/manipulation/_evalUrl.js +18 -0
- data/vendor/assets/components/jquery/src/manipulation/support.js +24 -0
- data/vendor/assets/components/jquery/src/manipulation/var/rcheckableType.js +3 -0
- data/vendor/assets/components/jquery/src/offset.js +204 -0
- data/vendor/assets/components/jquery/src/outro.js +1 -0
- data/vendor/assets/components/jquery/src/queue.js +142 -0
- data/vendor/assets/components/jquery/src/queue/delay.js +22 -0
- data/vendor/assets/components/jquery/src/selector-native.js +171 -0
- data/vendor/assets/components/jquery/src/selector-sizzle.js +14 -0
- data/vendor/assets/components/jquery/src/selector.js +1 -0
- data/vendor/assets/components/jquery/src/serialize.js +111 -0
- data/vendor/assets/components/jquery/src/sizzle/dist/sizzle.js +2015 -0
- data/vendor/assets/components/jquery/src/sizzle/dist/sizzle.min.js +3 -0
- data/vendor/assets/components/jquery/src/sizzle/dist/sizzle.min.map +1 -0
- data/vendor/assets/components/jquery/src/traversing.js +200 -0
- data/vendor/assets/components/jquery/src/traversing/findFilter.js +100 -0
- data/vendor/assets/components/jquery/src/traversing/var/rneedsContext.js +6 -0
- data/vendor/assets/components/jquery/src/var/arr.js +3 -0
- data/vendor/assets/components/jquery/src/var/class2type.js +4 -0
- data/vendor/assets/components/jquery/src/var/concat.js +5 -0
- data/vendor/assets/components/jquery/src/var/hasOwn.js +5 -0
- data/vendor/assets/components/jquery/src/var/indexOf.js +5 -0
- data/vendor/assets/components/jquery/src/var/pnum.js +3 -0
- data/vendor/assets/components/jquery/src/var/push.js +5 -0
- data/vendor/assets/components/jquery/src/var/rnotwhite.js +3 -0
- data/vendor/assets/components/jquery/src/var/slice.js +5 -0
- data/vendor/assets/components/jquery/src/var/strundefined.js +3 -0
- data/vendor/assets/components/jquery/src/var/support.js +4 -0
- data/vendor/assets/components/jquery/src/var/toString.js +5 -0
- data/vendor/assets/components/jquery/src/var/trim.js +3 -0
- data/vendor/assets/components/jquery/src/wrap.js +78 -0
- data/vendor/assets/components/moment/.bower.json +30 -0
- data/vendor/assets/components/moment/LICENSE +22 -0
- data/vendor/assets/components/moment/bower.json +20 -0
- data/vendor/assets/components/moment/lang/ar-ma.js +56 -0
- data/vendor/assets/components/moment/lang/ar-sa.js +96 -0
- data/vendor/assets/components/moment/lang/ar.js +97 -0
- data/vendor/assets/components/moment/lang/az.js +102 -0
- data/vendor/assets/components/moment/lang/bg.js +86 -0
- data/vendor/assets/components/moment/lang/bn.js +106 -0
- data/vendor/assets/components/moment/lang/br.js +107 -0
- data/vendor/assets/components/moment/lang/bs.js +139 -0
- data/vendor/assets/components/moment/lang/ca.js +66 -0
- data/vendor/assets/components/moment/lang/cs.js +155 -0
- data/vendor/assets/components/moment/lang/cv.js +59 -0
- data/vendor/assets/components/moment/lang/cy.js +77 -0
- data/vendor/assets/components/moment/lang/da.js +56 -0
- data/vendor/assets/components/moment/lang/de-at.js +72 -0
- data/vendor/assets/components/moment/lang/de.js +71 -0
- data/vendor/assets/components/moment/lang/el.js +90 -0
- data/vendor/assets/components/moment/lang/en-au.js +62 -0
- data/vendor/assets/components/moment/lang/en-ca.js +59 -0
- data/vendor/assets/components/moment/lang/en-gb.js +63 -0
- data/vendor/assets/components/moment/lang/eo.js +65 -0
- data/vendor/assets/components/moment/lang/es.js +75 -0
- data/vendor/assets/components/moment/lang/et.js +76 -0
- data/vendor/assets/components/moment/lang/eu.js +60 -0
- data/vendor/assets/components/moment/lang/fa.js +97 -0
- data/vendor/assets/components/moment/lang/fi.js +103 -0
- data/vendor/assets/components/moment/lang/fo.js +56 -0
- data/vendor/assets/components/moment/lang/fr-ca.js +54 -0
- data/vendor/assets/components/moment/lang/fr.js +58 -0
- data/vendor/assets/components/moment/lang/gl.js +71 -0
- data/vendor/assets/components/moment/lang/he.js +77 -0
- data/vendor/assets/components/moment/lang/hi.js +105 -0
- data/vendor/assets/components/moment/lang/hr.js +140 -0
- data/vendor/assets/components/moment/lang/hu.js +105 -0
- data/vendor/assets/components/moment/lang/hy-am.js +113 -0
- data/vendor/assets/components/moment/lang/id.js +67 -0
- data/vendor/assets/components/moment/lang/is.js +124 -0
- data/vendor/assets/components/moment/lang/it.js +59 -0
- data/vendor/assets/components/moment/lang/ja.js +58 -0
- data/vendor/assets/components/moment/lang/ka.js +108 -0
- data/vendor/assets/components/moment/lang/km.js +55 -0
- data/vendor/assets/components/moment/lang/ko.js +63 -0
- data/vendor/assets/components/moment/lang/lb.js +160 -0
- data/vendor/assets/components/moment/lang/lt.js +118 -0
- data/vendor/assets/components/moment/lang/lv.js +77 -0
- data/vendor/assets/components/moment/lang/mk.js +86 -0
- data/vendor/assets/components/moment/lang/ml.js +64 -0
- data/vendor/assets/components/moment/lang/mr.js +104 -0
- data/vendor/assets/components/moment/lang/ms-my.js +66 -0
- data/vendor/assets/components/moment/lang/nb.js +57 -0
- data/vendor/assets/components/moment/lang/ne.js +105 -0
- data/vendor/assets/components/moment/lang/nl.js +67 -0
- data/vendor/assets/components/moment/lang/nn.js +56 -0
- data/vendor/assets/components/moment/lang/pl.js +98 -0
- data/vendor/assets/components/moment/lang/pt-br.js +56 -0
- data/vendor/assets/components/moment/lang/pt.js +60 -0
- data/vendor/assets/components/moment/lang/ro.js +72 -0
- data/vendor/assets/components/moment/lang/ru.js +166 -0
- data/vendor/assets/components/moment/lang/sk.js +156 -0
- data/vendor/assets/components/moment/lang/sl.js +144 -0
- data/vendor/assets/components/moment/lang/sq.js +61 -0
- data/vendor/assets/components/moment/lang/sr-cyrl.js +106 -0
- data/vendor/assets/components/moment/lang/sr.js +106 -0
- data/vendor/assets/components/moment/lang/sv.js +63 -0
- data/vendor/assets/components/moment/lang/ta.js +112 -0
- data/vendor/assets/components/moment/lang/th.js +58 -0
- data/vendor/assets/components/moment/lang/tl-ph.js +58 -0
- data/vendor/assets/components/moment/lang/tr.js +93 -0
- data/vendor/assets/components/moment/lang/tzm-latn.js +55 -0
- data/vendor/assets/components/moment/lang/tzm.js +55 -0
- data/vendor/assets/components/moment/lang/uk.js +157 -0
- data/vendor/assets/components/moment/lang/uz.js +55 -0
- data/vendor/assets/components/moment/lang/vi.js +62 -0
- data/vendor/assets/components/moment/lang/zh-cn.js +108 -0
- data/vendor/assets/components/moment/lang/zh-tw.js +84 -0
- data/vendor/assets/components/moment/min/langs.js +6426 -0
- data/vendor/assets/components/moment/min/langs.min.js +4 -0
- data/vendor/assets/components/moment/min/moment-with-langs.js +8521 -0
- data/vendor/assets/components/moment/min/moment-with-langs.min.js +9 -0
- data/vendor/assets/components/moment/min/moment.min.js +6 -0
- data/vendor/assets/components/moment/moment.js +2610 -0
- data/vendor/assets/components/moment/readme.md +388 -0
- data/vendor/assets/components/numeral/.bower.json +28 -0
- data/vendor/assets/components/numeral/.gitignore +29 -0
- data/vendor/assets/components/numeral/.travis.yml +7 -0
- data/vendor/assets/components/numeral/Gruntfile.js +91 -0
- data/vendor/assets/components/numeral/LICENSE +22 -0
- data/vendor/assets/components/numeral/README.md +213 -0
- data/vendor/assets/components/numeral/bower.json +16 -0
- data/vendor/assets/components/numeral/component.json +16 -0
- data/vendor/assets/components/numeral/languages.js +989 -0
- data/vendor/assets/components/numeral/languages/be-nl.js +35 -0
- data/vendor/assets/components/numeral/languages/chs.js +34 -0
- data/vendor/assets/components/numeral/languages/cs.js +34 -0
- data/vendor/assets/components/numeral/languages/da-dk.js +34 -0
- data/vendor/assets/components/numeral/languages/de-ch.js +34 -0
- data/vendor/assets/components/numeral/languages/de.js +34 -0
- data/vendor/assets/components/numeral/languages/en-gb.js +38 -0
- data/vendor/assets/components/numeral/languages/es-ES.js +39 -0
- data/vendor/assets/components/numeral/languages/es.js +39 -0
- data/vendor/assets/components/numeral/languages/et.js +37 -0
- data/vendor/assets/components/numeral/languages/fi.js +34 -0
- data/vendor/assets/components/numeral/languages/fr-CA.js +34 -0
- data/vendor/assets/components/numeral/languages/fr-ch.js +34 -0
- data/vendor/assets/components/numeral/languages/fr.js +34 -0
- data/vendor/assets/components/numeral/languages/hu.js +34 -0
- data/vendor/assets/components/numeral/languages/it.js +34 -0
- data/vendor/assets/components/numeral/languages/ja.js +34 -0
- data/vendor/assets/components/numeral/languages/nl-nl.js +35 -0
- data/vendor/assets/components/numeral/languages/pl.js +34 -0
- data/vendor/assets/components/numeral/languages/pt-br.js +34 -0
- data/vendor/assets/components/numeral/languages/pt-pt.js +34 -0
- data/vendor/assets/components/numeral/languages/ru-UA.js +35 -0
- data/vendor/assets/components/numeral/languages/ru.js +37 -0
- data/vendor/assets/components/numeral/languages/sk.js +34 -0
- data/vendor/assets/components/numeral/languages/th.js +34 -0
- data/vendor/assets/components/numeral/languages/tr.js +67 -0
- data/vendor/assets/components/numeral/languages/uk-UA.js +35 -0
- data/vendor/assets/components/numeral/min/languages.min.js +129 -0
- data/vendor/assets/components/numeral/min/languages/be-nl.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/chs.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/cs.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/da-dk.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/de-ch.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/de.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/en-gb.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/es-ES.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/es.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/et.min.js +9 -0
- data/vendor/assets/components/numeral/min/languages/fi.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/fr-CA.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/fr-ch.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/fr.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/hu.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/it.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/ja.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/nl-nl.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/pl.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/pt-br.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/pt-pt.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/ru-UA.min.js +1 -0
- data/vendor/assets/components/numeral/min/languages/ru.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/sk.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/th.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/tr.min.js +6 -0
- data/vendor/assets/components/numeral/min/languages/uk-UA.min.js +1 -0
- data/vendor/assets/components/numeral/min/numeral.min.js +8 -0
- data/vendor/assets/components/numeral/numeral.js +679 -0
- data/vendor/assets/components/numeral/package.json +50 -0
- data/vendor/assets/components/numeral/tests/languages/be-nl.js +107 -0
- data/vendor/assets/components/numeral/tests/languages/chs.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/cs.js +102 -0
- data/vendor/assets/components/numeral/tests/languages/da-dk.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/de-ch.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/de.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/en-gb.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/en.js +98 -0
- data/vendor/assets/components/numeral/tests/languages/es-ES.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/es.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/et.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/fi.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/fr-CA.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/fr-ch.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/fr.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/hu.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/it.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/ja.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/nl-nl.js +109 -0
- data/vendor/assets/components/numeral/tests/languages/pl.js +102 -0
- data/vendor/assets/components/numeral/tests/languages/pt-br.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/pt-pt.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/ru-UA.js +102 -0
- data/vendor/assets/components/numeral/tests/languages/ru.js +102 -0
- data/vendor/assets/components/numeral/tests/languages/sk.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/th.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/tr.js +101 -0
- data/vendor/assets/components/numeral/tests/languages/uk-UA.js +102 -0
- data/vendor/assets/components/numeral/tests/numeral/format.js +204 -0
- data/vendor/assets/components/numeral/tests/numeral/manipulate.js +104 -0
- data/vendor/assets/components/numeral/tests/numeral/misc.js +123 -0
- data/vendor/assets/components/numeral/tests/numeral/unformat.js +96 -0
- data/vendor/assets/components/qunit-bdd/.bower.json +31 -0
- data/vendor/assets/components/qunit-bdd/LICENSE +13 -0
- data/vendor/assets/components/qunit-bdd/README.md +282 -0
- data/vendor/assets/components/qunit-bdd/bower.json +22 -0
- data/vendor/assets/components/qunit-bdd/karma.conf.js +70 -0
- data/vendor/assets/components/qunit-bdd/lib/qunit-bdd.js +755 -0
- data/vendor/assets/components/qunit-bdd/package.json +33 -0
- data/vendor/assets/javascripts/bs-breadcrumbs.js +85 -0
- data/vendor/assets/javascripts/bs-core.js +476 -0
- data/vendor/assets/javascripts/bs-notifications.js +111 -0
- data/vendor/assets/javascripts/daterangepicker.js +1030 -0
- data/vendor/assets/javascripts/fix_bind_phantomjs.js +37 -0
- data/vendor/assets/javascripts/jquery-deparam.js +97 -0
- data/vendor/assets/javascripts/sidebar-tree.js +68 -0
- data/vendor/assets/stylesheets/daterangepicker.css +271 -0
- metadata +766 -0
|
@@ -0,0 +1,312 @@
|
|
|
1
|
+
(function(global) {
|
|
2
|
+
|
|
3
|
+
Ember.libraries.register('Ember Simple Auth Devise', '0.6.4');
|
|
4
|
+
|
|
5
|
+
var define, requireModule;
|
|
6
|
+
|
|
7
|
+
(function() {
|
|
8
|
+
var registry = {}, seen = {};
|
|
9
|
+
|
|
10
|
+
define = function(name, deps, callback) {
|
|
11
|
+
registry[name] = { deps: deps, callback: callback };
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
requireModule = function(name) {
|
|
15
|
+
if (seen.hasOwnProperty(name)) { return seen[name]; }
|
|
16
|
+
seen[name] = {};
|
|
17
|
+
|
|
18
|
+
if (!registry[name]) {
|
|
19
|
+
throw new Error("Could not find module " + name);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
var mod = registry[name],
|
|
23
|
+
deps = mod.deps,
|
|
24
|
+
callback = mod.callback,
|
|
25
|
+
reified = [],
|
|
26
|
+
exports;
|
|
27
|
+
|
|
28
|
+
for (var i=0, l=deps.length; i<l; i++) {
|
|
29
|
+
if (deps[i] === 'exports') {
|
|
30
|
+
reified.push(exports = {});
|
|
31
|
+
} else {
|
|
32
|
+
reified.push(requireModule(resolve(deps[i])));
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
var value = callback.apply(this, reified);
|
|
37
|
+
return seen[name] = exports || value;
|
|
38
|
+
|
|
39
|
+
function resolve(child) {
|
|
40
|
+
if (child.charAt(0) !== '.') { return child; }
|
|
41
|
+
var parts = child.split("/");
|
|
42
|
+
var parentBase = name.split("/").slice(0, -1);
|
|
43
|
+
|
|
44
|
+
for (var i=0, l=parts.length; i<l; i++) {
|
|
45
|
+
var part = parts[i];
|
|
46
|
+
|
|
47
|
+
if (part === '..') { parentBase.pop(); }
|
|
48
|
+
else if (part === '.') { continue; }
|
|
49
|
+
else { parentBase.push(part); }
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
return parentBase.join("/");
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
requireModule.registry = registry;
|
|
57
|
+
})();
|
|
58
|
+
|
|
59
|
+
define("simple-auth-devise/authenticators/devise",
|
|
60
|
+
["simple-auth/authenticators/base","simple-auth/utils/is-secure-url","simple-auth/utils/get-global-config","exports"],
|
|
61
|
+
function(__dependency1__, __dependency2__, __dependency3__, __exports__) {
|
|
62
|
+
"use strict";
|
|
63
|
+
var Base = __dependency1__["default"];
|
|
64
|
+
var isSecureUrl = __dependency2__["default"];
|
|
65
|
+
var getGlobalConfig = __dependency3__["default"];
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
Authenticator that works with the Ruby gem
|
|
69
|
+
[Devise](https://github.com/plataformatec/devise).
|
|
70
|
+
|
|
71
|
+
__As token authentication is not actually part of devise anymore, the server
|
|
72
|
+
needs to implement some customizations__ to work with this authenticator -
|
|
73
|
+
see the README and
|
|
74
|
+
[discussion here](https://gist.github.com/josevalim/fb706b1e933ef01e4fb6).
|
|
75
|
+
|
|
76
|
+
_The factory for this authenticator is registered as
|
|
77
|
+
`'simple-auth-authenticator:devise'` in Ember's container._
|
|
78
|
+
|
|
79
|
+
@class Devise
|
|
80
|
+
@namespace SimpleAuth.Authenticators
|
|
81
|
+
@module simple-auth-devise/authenticators/devise
|
|
82
|
+
@extends Base
|
|
83
|
+
*/
|
|
84
|
+
__exports__["default"] = Base.extend({
|
|
85
|
+
/**
|
|
86
|
+
The endpoint on the server the authenticator acquires the auth token
|
|
87
|
+
and email from.
|
|
88
|
+
|
|
89
|
+
This value can be configured via the global environment object:
|
|
90
|
+
|
|
91
|
+
```js
|
|
92
|
+
window.ENV = window.ENV || {};
|
|
93
|
+
window.ENV['simple-auth-devise'] = {
|
|
94
|
+
serverTokenEndpoint: '/some/other/endpoint'
|
|
95
|
+
}
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
@property serverTokenEndpoint
|
|
99
|
+
@type String
|
|
100
|
+
@default '/users/sign_in'
|
|
101
|
+
*/
|
|
102
|
+
serverTokenEndpoint: '/users/sign_in',
|
|
103
|
+
|
|
104
|
+
/**
|
|
105
|
+
The devise resource name
|
|
106
|
+
|
|
107
|
+
This value can be configured via the global environment object:
|
|
108
|
+
|
|
109
|
+
```js
|
|
110
|
+
window.ENV = window.ENV || {};
|
|
111
|
+
window.ENV['simple-auth-devise'] = {
|
|
112
|
+
resourceName: 'account'
|
|
113
|
+
}
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
@property resourceName
|
|
117
|
+
@type String
|
|
118
|
+
@default 'user'
|
|
119
|
+
*/
|
|
120
|
+
resourceName: 'user',
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
@method init
|
|
124
|
+
@private
|
|
125
|
+
*/
|
|
126
|
+
init: function() {
|
|
127
|
+
var globalConfig = getGlobalConfig('simple-auth-devise');
|
|
128
|
+
this.serverTokenEndpoint = globalConfig.serverTokenEndpoint || this.serverTokenEndpoint;
|
|
129
|
+
this.resourceName = globalConfig.resourceName || this.resourceName;
|
|
130
|
+
},
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
Restores the session from a set of session properties; __will return a
|
|
134
|
+
resolving promise when there's a non-empty `user_token` and a non-empty
|
|
135
|
+
`user_email` in the `properties`__ and a rejecting promise otherwise.
|
|
136
|
+
|
|
137
|
+
@method restore
|
|
138
|
+
@param {Object} properties The properties to restore the session from
|
|
139
|
+
@return {Ember.RSVP.Promise} A promise that when it resolves results in the session being authenticated
|
|
140
|
+
*/
|
|
141
|
+
restore: function(properties) {
|
|
142
|
+
return new Ember.RSVP.Promise(function(resolve, reject) {
|
|
143
|
+
if (!Ember.isEmpty(properties.user_token) && !Ember.isEmpty(properties.user_email)) {
|
|
144
|
+
resolve(properties);
|
|
145
|
+
} else {
|
|
146
|
+
reject();
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
},
|
|
150
|
+
|
|
151
|
+
/**
|
|
152
|
+
Authenticates the session with the specified `credentials`; the credentials
|
|
153
|
+
are `POST`ed to the
|
|
154
|
+
[`Authenticators.Devise#serverTokenEndpoint`](#SimpleAuth-Authenticators-Devise-serverTokenEndpoint)
|
|
155
|
+
and if they are valid the server returns an auth token and email in
|
|
156
|
+
response. __If the credentials are valid and authentication succeeds, a
|
|
157
|
+
promise that resolves with the server's response is returned__, otherwise a
|
|
158
|
+
promise that rejects with the server error is returned.
|
|
159
|
+
|
|
160
|
+
@method authenticate
|
|
161
|
+
@param {Object} options The credentials to authenticate the session with
|
|
162
|
+
@return {Ember.RSVP.Promise} A promise that resolves when an auth token and email is successfully acquired from the server and rejects otherwise
|
|
163
|
+
*/
|
|
164
|
+
authenticate: function(credentials) {
|
|
165
|
+
var _this = this;
|
|
166
|
+
return new Ember.RSVP.Promise(function(resolve, reject) {
|
|
167
|
+
var data = {};
|
|
168
|
+
data[_this.resourceName] = {
|
|
169
|
+
email: credentials.identification,
|
|
170
|
+
password: credentials.password
|
|
171
|
+
};
|
|
172
|
+
_this.makeRequest(data).then(function(response) {
|
|
173
|
+
Ember.run(function() {
|
|
174
|
+
resolve(response);
|
|
175
|
+
});
|
|
176
|
+
}, function(xhr, status, error) {
|
|
177
|
+
Ember.run(function() {
|
|
178
|
+
reject(xhr.responseJSON || xhr.responseText);
|
|
179
|
+
});
|
|
180
|
+
});
|
|
181
|
+
});
|
|
182
|
+
},
|
|
183
|
+
|
|
184
|
+
/**
|
|
185
|
+
Does nothing
|
|
186
|
+
|
|
187
|
+
@method invalidate
|
|
188
|
+
@return {Ember.RSVP.Promise} A resolving promise
|
|
189
|
+
*/
|
|
190
|
+
invalidate: function() {
|
|
191
|
+
return Ember.RSVP.resolve();
|
|
192
|
+
},
|
|
193
|
+
|
|
194
|
+
/**
|
|
195
|
+
@method makeRequest
|
|
196
|
+
@private
|
|
197
|
+
*/
|
|
198
|
+
makeRequest: function(data, resolve, reject) {
|
|
199
|
+
if (!isSecureUrl(this.serverTokenEndpoint)) {
|
|
200
|
+
Ember.Logger.warn('Credentials are transmitted via an insecure connection - use HTTPS to keep them secure.');
|
|
201
|
+
}
|
|
202
|
+
return Ember.$.ajax({
|
|
203
|
+
url: this.serverTokenEndpoint,
|
|
204
|
+
type: 'POST',
|
|
205
|
+
data: data,
|
|
206
|
+
dataType: 'json',
|
|
207
|
+
beforeSend: function(xhr, settings) {
|
|
208
|
+
xhr.setRequestHeader('Accept', settings.accepts.json);
|
|
209
|
+
}
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
});
|
|
213
|
+
});
|
|
214
|
+
define("simple-auth-devise/authorizers/devise",
|
|
215
|
+
["simple-auth/authorizers/base","simple-auth/utils/is-secure-url","exports"],
|
|
216
|
+
function(__dependency1__, __dependency2__, __exports__) {
|
|
217
|
+
"use strict";
|
|
218
|
+
var Base = __dependency1__["default"];
|
|
219
|
+
var isSecureUrl = __dependency2__["default"];
|
|
220
|
+
|
|
221
|
+
/**
|
|
222
|
+
Authenticator that works with the Ruby gem
|
|
223
|
+
[Devise](https://github.com/plataformatec/devise) by sending the `user_token`
|
|
224
|
+
and `user_email` properties from the session in the `Authorization` header.
|
|
225
|
+
|
|
226
|
+
__As token authentication is not actually part of devise anymore, the server
|
|
227
|
+
needs to implement some customizations__ to work with this authenticator -
|
|
228
|
+
see the README for more information.
|
|
229
|
+
|
|
230
|
+
_The factory for this authorizer is registered as
|
|
231
|
+
`'simple-auth-authorizer:devise'` in Ember's container._
|
|
232
|
+
|
|
233
|
+
@class Devise
|
|
234
|
+
@namespace SimpleAuth.Authorizers
|
|
235
|
+
@module simple-auth-devise/authorizers/devise
|
|
236
|
+
@extends Base
|
|
237
|
+
*/
|
|
238
|
+
__exports__["default"] = Base.extend({
|
|
239
|
+
/**
|
|
240
|
+
Authorizes an XHR request by sending the `user_token` and `user_email`
|
|
241
|
+
properties from the session in the `Authorization` header:
|
|
242
|
+
|
|
243
|
+
```
|
|
244
|
+
Authorization: Token token="<user_token>", user_email="<user_email>"
|
|
245
|
+
```
|
|
246
|
+
|
|
247
|
+
@method authorize
|
|
248
|
+
@param {jqXHR} jqXHR The XHR request to authorize (see http://api.jquery.com/jQuery.ajax/#jqXHR)
|
|
249
|
+
@param {Object} requestOptions The options as provided to the `$.ajax` method (see http://api.jquery.com/jQuery.ajaxPrefilter/)
|
|
250
|
+
*/
|
|
251
|
+
|
|
252
|
+
authorize: function(jqXHR, requestOptions) {
|
|
253
|
+
var userToken = this.get('session.user_token');
|
|
254
|
+
var userEmail = this.get('session.user_email');
|
|
255
|
+
if (this.get('session.isAuthenticated') && !Ember.isEmpty(userToken) && !Ember.isEmpty(userEmail)) {
|
|
256
|
+
if (!isSecureUrl(requestOptions.url)) {
|
|
257
|
+
Ember.Logger.warn('Credentials are transmitted via an insecure connection - use HTTPS to keep them secure.');
|
|
258
|
+
}
|
|
259
|
+
var authData = 'token="' + userToken + '", user_email="' + userEmail + '"';
|
|
260
|
+
jqXHR.setRequestHeader('Authorization', 'Token ' + authData);
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
});
|
|
264
|
+
});
|
|
265
|
+
define("simple-auth-devise/ember",
|
|
266
|
+
["./initializer"],
|
|
267
|
+
function(__dependency1__) {
|
|
268
|
+
"use strict";
|
|
269
|
+
var initializer = __dependency1__["default"];
|
|
270
|
+
|
|
271
|
+
Ember.onLoad('Ember.Application', function(Application) {
|
|
272
|
+
Application.initializer(initializer);
|
|
273
|
+
});
|
|
274
|
+
});
|
|
275
|
+
define("simple-auth-devise/initializer",
|
|
276
|
+
["simple-auth-devise/authenticators/devise","simple-auth-devise/authorizers/devise","exports"],
|
|
277
|
+
function(__dependency1__, __dependency2__, __exports__) {
|
|
278
|
+
"use strict";
|
|
279
|
+
var Authenticator = __dependency1__["default"];
|
|
280
|
+
var Authorizer = __dependency2__["default"];
|
|
281
|
+
|
|
282
|
+
__exports__["default"] = {
|
|
283
|
+
name: 'simple-auth-devise',
|
|
284
|
+
before: 'simple-auth',
|
|
285
|
+
initialize: function(container, application) {
|
|
286
|
+
container.register('simple-auth-authorizer:devise', Authorizer);
|
|
287
|
+
container.register('simple-auth-authenticator:devise', Authenticator);
|
|
288
|
+
}
|
|
289
|
+
};
|
|
290
|
+
});
|
|
291
|
+
define('simple-auth/authenticators/base', ['exports'], function(__exports__) {
|
|
292
|
+
__exports__['default'] = global.SimpleAuth.Authenticators.Base;
|
|
293
|
+
});
|
|
294
|
+
define('simple-auth/authorizers/base', ['exports'], function(__exports__) {
|
|
295
|
+
__exports__['default'] = global.SimpleAuth.Authorizers.Base;
|
|
296
|
+
});
|
|
297
|
+
define('simple-auth/utils/is-secure-url', ['exports'], function(__exports__) {
|
|
298
|
+
__exports__['default'] = global.SimpleAuth.Utils.isSecureUrl;
|
|
299
|
+
});
|
|
300
|
+
define('simple-auth/utils/get-global-config', ['exports'], function(__exports__) {
|
|
301
|
+
__exports__['default'] = global.SimpleAuth.Utils.getGlobalConfig;
|
|
302
|
+
});
|
|
303
|
+
|
|
304
|
+
var initializer = requireModule('simple-auth-devise/initializer').default;
|
|
305
|
+
var Authenticator = requireModule('simple-auth-devise/authenticators/devise').default;
|
|
306
|
+
var Authorizer = requireModule('simple-auth-devise/authorizers/devise').default;
|
|
307
|
+
|
|
308
|
+
global.SimpleAuth.Authenticators.Devise = Authenticator;
|
|
309
|
+
global.SimpleAuth.Authorizers.Devise = Authorizer;
|
|
310
|
+
|
|
311
|
+
requireModule('simple-auth-devise/ember');
|
|
312
|
+
})((typeof global !== 'undefined') ? global : window);
|
|
@@ -0,0 +1,386 @@
|
|
|
1
|
+
(function(global) {
|
|
2
|
+
var define = global.define;
|
|
3
|
+
var require = global.require;
|
|
4
|
+
var Ember = global.Ember;
|
|
5
|
+
if (typeof Ember === 'undefined' && typeof require !== 'undefined') {
|
|
6
|
+
Ember = require('ember');
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
Ember.libraries.register('Ember Simple Auth OAuth 2.0', '0.6.4');
|
|
10
|
+
|
|
11
|
+
define("simple-auth-oauth2/authenticators/oauth2",
|
|
12
|
+
["simple-auth/authenticators/base","simple-auth/utils/is-secure-url","simple-auth/utils/get-global-config","exports"],
|
|
13
|
+
function(__dependency1__, __dependency2__, __dependency3__, __exports__) {
|
|
14
|
+
"use strict";
|
|
15
|
+
var Base = __dependency1__["default"];
|
|
16
|
+
var isSecureUrl = __dependency2__["default"];
|
|
17
|
+
var getGlobalConfig = __dependency3__["default"];
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
Authenticator that conforms to OAuth 2
|
|
21
|
+
([RFC 6749](http://tools.ietf.org/html/rfc6749)), specifically the _"Resource
|
|
22
|
+
Owner Password Credentials Grant Type"_.
|
|
23
|
+
|
|
24
|
+
This authenticator supports access token refresh (see
|
|
25
|
+
[RFC 6740, section 6](http://tools.ietf.org/html/rfc6749#section-6)).
|
|
26
|
+
|
|
27
|
+
_The factory for this authenticator is registered as
|
|
28
|
+
`'simple-auth-authenticator:oauth2-password-grant'` in Ember's
|
|
29
|
+
container._
|
|
30
|
+
|
|
31
|
+
@class OAuth2
|
|
32
|
+
@namespace SimpleAuth.Authenticators
|
|
33
|
+
@module simple-auth-oauth2/authenticators/oauth2
|
|
34
|
+
@extends Base
|
|
35
|
+
*/
|
|
36
|
+
__exports__["default"] = Base.extend({
|
|
37
|
+
/**
|
|
38
|
+
Triggered when the authenticator refreshes the access token (see
|
|
39
|
+
[RFC 6740, section 6](http://tools.ietf.org/html/rfc6749#section-6)).
|
|
40
|
+
|
|
41
|
+
@event updated
|
|
42
|
+
@param {Object} data The updated session data
|
|
43
|
+
*/
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
The endpoint on the server the authenticator acquires the access token
|
|
47
|
+
from.
|
|
48
|
+
|
|
49
|
+
This value can be configured via the global environment object:
|
|
50
|
+
|
|
51
|
+
```js
|
|
52
|
+
window.ENV = window.ENV || {};
|
|
53
|
+
window.ENV['simple-auth-oauth2'] = {
|
|
54
|
+
serverTokenEndpoint: '/some/custom/endpoint'
|
|
55
|
+
}
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
@property serverTokenEndpoint
|
|
59
|
+
@type String
|
|
60
|
+
@default '/token'
|
|
61
|
+
*/
|
|
62
|
+
serverTokenEndpoint: '/token',
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
The endpoint on the server the authenticator uses to revoke tokens. Only
|
|
66
|
+
set this if the server actually supports token revokation.
|
|
67
|
+
|
|
68
|
+
This value can be configured via the global environment object:
|
|
69
|
+
|
|
70
|
+
```js
|
|
71
|
+
window.ENV = window.ENV || {};
|
|
72
|
+
window.ENV['simple-auth-oauth2'] = {
|
|
73
|
+
serverTokenRevokationEndpoint: '/some/custom/endpoint'
|
|
74
|
+
}
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
@property serverTokenRevokationEndpoint
|
|
78
|
+
@type String
|
|
79
|
+
@default null
|
|
80
|
+
*/
|
|
81
|
+
serverTokenRevokationEndpoint: null,
|
|
82
|
+
|
|
83
|
+
/**
|
|
84
|
+
Sets whether the authenticator automatically refreshes access tokens.
|
|
85
|
+
|
|
86
|
+
This value can be configured via the global environment object:
|
|
87
|
+
|
|
88
|
+
```js
|
|
89
|
+
window.ENV = window.ENV || {};
|
|
90
|
+
window.ENV['simple-auth-oauth2'] = {
|
|
91
|
+
refreshAccessTokens: false
|
|
92
|
+
}
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
@property refreshAccessTokens
|
|
96
|
+
@type Boolean
|
|
97
|
+
@default true
|
|
98
|
+
*/
|
|
99
|
+
refreshAccessTokens: true,
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
@property _refreshTokenTimeout
|
|
103
|
+
@private
|
|
104
|
+
*/
|
|
105
|
+
_refreshTokenTimeout: null,
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
@method init
|
|
109
|
+
@private
|
|
110
|
+
*/
|
|
111
|
+
init: function() {
|
|
112
|
+
var globalConfig = getGlobalConfig('simple-auth-oauth2');
|
|
113
|
+
this.serverTokenEndpoint = globalConfig.serverTokenEndpoint || this.serverTokenEndpoint;
|
|
114
|
+
this.serverTokenRevokationEndpoint = globalConfig.serverTokenRevokationEndpoint || this.serverTokenRevokationEndpoint;
|
|
115
|
+
this.refreshAccessTokens = globalConfig.refreshAccessTokens || this.refreshAccessTokens;
|
|
116
|
+
},
|
|
117
|
+
|
|
118
|
+
/**
|
|
119
|
+
Restores the session from a set of session properties; __will return a
|
|
120
|
+
resolving promise when there's a non-empty `access_token` in the `data`__
|
|
121
|
+
and a rejecting promise otherwise.
|
|
122
|
+
|
|
123
|
+
This method also schedules automatic token refreshing when there are values
|
|
124
|
+
for `refresh_token` and `expires_in` in the `data` and automatic token
|
|
125
|
+
refreshing is not disabled (see
|
|
126
|
+
[`Authenticators.OAuth2#refreshAccessTokens`](#SimpleAuth-Authenticators-OAuth2-refreshAccessTokens)).
|
|
127
|
+
|
|
128
|
+
@method restore
|
|
129
|
+
@param {Object} data The data to restore the session from
|
|
130
|
+
@return {Ember.RSVP.Promise} A promise that when it resolves results in the session being authenticated
|
|
131
|
+
*/
|
|
132
|
+
restore: function(data) {
|
|
133
|
+
var _this = this;
|
|
134
|
+
return new Ember.RSVP.Promise(function(resolve, reject) {
|
|
135
|
+
var now = (new Date()).getTime();
|
|
136
|
+
if (!Ember.isEmpty(data.expires_at) && data.expires_at < now) {
|
|
137
|
+
if (_this.refreshAccessTokens) {
|
|
138
|
+
_this.refreshAccessToken(data.expires_in, data.refresh_token).then(function(data) {
|
|
139
|
+
resolve(data);
|
|
140
|
+
}, reject);
|
|
141
|
+
} else {
|
|
142
|
+
reject();
|
|
143
|
+
}
|
|
144
|
+
} else {
|
|
145
|
+
if (Ember.isEmpty(data.access_token)) {
|
|
146
|
+
reject();
|
|
147
|
+
} else {
|
|
148
|
+
_this.scheduleAccessTokenRefresh(data.expires_in, data.expires_at, data.refresh_token);
|
|
149
|
+
resolve(data);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
},
|
|
154
|
+
|
|
155
|
+
/**
|
|
156
|
+
Authenticates the session with the specified `credentials`; the credentials
|
|
157
|
+
are send via a _"POST"_ request to the
|
|
158
|
+
[`Authenticators.OAuth2#serverTokenEndpoint`](#SimpleAuth-Authenticators-OAuth2-serverTokenEndpoint)
|
|
159
|
+
and if they are valid the server returns an access token in response (see
|
|
160
|
+
http://tools.ietf.org/html/rfc6749#section-4.3). __If the credentials are
|
|
161
|
+
valid and authentication succeeds, a promise that resolves with the
|
|
162
|
+
server's response is returned__, otherwise a promise that rejects with the
|
|
163
|
+
error is returned.
|
|
164
|
+
|
|
165
|
+
This method also schedules automatic token refreshing when there are values
|
|
166
|
+
for `refresh_token` and `expires_in` in the server response and automatic
|
|
167
|
+
token refreshing is not disabled (see
|
|
168
|
+
[`Authenticators.OAuth2#refreshAccessTokens`](#SimpleAuth-Authenticators-OAuth2-refreshAccessTokens)).
|
|
169
|
+
|
|
170
|
+
@method authenticate
|
|
171
|
+
@param {Object} credentials The credentials to authenticate the session with
|
|
172
|
+
@return {Ember.RSVP.Promise} A promise that resolves when an access token is successfully acquired from the server and rejects otherwise
|
|
173
|
+
*/
|
|
174
|
+
authenticate: function(credentials) {
|
|
175
|
+
var _this = this;
|
|
176
|
+
return new Ember.RSVP.Promise(function(resolve, reject) {
|
|
177
|
+
var data = { grant_type: 'password', username: credentials.identification, password: credentials.password };
|
|
178
|
+
_this.makeRequest(_this.serverTokenEndpoint, data).then(function(response) {
|
|
179
|
+
Ember.run(function() {
|
|
180
|
+
var expiresAt = _this.absolutizeExpirationTime(response.expires_in);
|
|
181
|
+
_this.scheduleAccessTokenRefresh(response.expires_in, expiresAt, response.refresh_token);
|
|
182
|
+
if (!Ember.isEmpty(expiresAt)) {
|
|
183
|
+
response = Ember.merge(response, { expires_at: expiresAt });
|
|
184
|
+
}
|
|
185
|
+
resolve(response);
|
|
186
|
+
});
|
|
187
|
+
}, function(xhr, status, error) {
|
|
188
|
+
Ember.run(function() {
|
|
189
|
+
reject(xhr.responseJSON || xhr.responseText);
|
|
190
|
+
});
|
|
191
|
+
});
|
|
192
|
+
});
|
|
193
|
+
},
|
|
194
|
+
|
|
195
|
+
/**
|
|
196
|
+
Cancels any outstanding automatic token refreshes and returns a resolving
|
|
197
|
+
promise.
|
|
198
|
+
|
|
199
|
+
@method invalidate
|
|
200
|
+
@param {Object} data The data of the session to be invalidated
|
|
201
|
+
@return {Ember.RSVP.Promise} A resolving promise
|
|
202
|
+
*/
|
|
203
|
+
invalidate: function(data) {
|
|
204
|
+
var _this = this;
|
|
205
|
+
function success(resolve) {
|
|
206
|
+
Ember.run.cancel(_this._refreshTokenTimeout);
|
|
207
|
+
delete _this._refreshTokenTimeout;
|
|
208
|
+
resolve();
|
|
209
|
+
}
|
|
210
|
+
return new Ember.RSVP.Promise(function(resolve, reject) {
|
|
211
|
+
if (!Ember.isEmpty(_this.serverTokenRevokationEndpoint)) {
|
|
212
|
+
var requests = [];
|
|
213
|
+
Ember.A(['access_token', 'refresh_token']).forEach(function(tokenType) {
|
|
214
|
+
if (!Ember.isEmpty(data[tokenType])) {
|
|
215
|
+
requests.push(_this.makeRequest(_this.serverTokenRevokationEndpoint, {
|
|
216
|
+
token_type_hint: tokenType, token: data[tokenType]
|
|
217
|
+
}));
|
|
218
|
+
}
|
|
219
|
+
});
|
|
220
|
+
Ember.$.when.apply(Ember.$, requests).always(function(responses) {
|
|
221
|
+
success(resolve);
|
|
222
|
+
});
|
|
223
|
+
} else {
|
|
224
|
+
success(resolve);
|
|
225
|
+
}
|
|
226
|
+
});
|
|
227
|
+
},
|
|
228
|
+
|
|
229
|
+
/**
|
|
230
|
+
Sends an `AJAX` request to the `url`. This will always be a _"POST"_
|
|
231
|
+
request with content type _"application/x-www-form-urlencoded"_ as
|
|
232
|
+
specified in [RFC 6749](http://tools.ietf.org/html/rfc6749).
|
|
233
|
+
|
|
234
|
+
This method is not meant to be used directly but serves as an extension
|
|
235
|
+
point to e.g. add _"Client Credentials"_ (see
|
|
236
|
+
[RFC 6749, section 2.3](http://tools.ietf.org/html/rfc6749#section-2.3)).
|
|
237
|
+
|
|
238
|
+
@method makeRequest
|
|
239
|
+
@param {Object} url The url to send the request to
|
|
240
|
+
@param {Object} data The data to send with the request, e.g. username and password or the refresh token
|
|
241
|
+
@return {Deferred object} A Deferred object (see [the jQuery docs](http://api.jquery.com/category/deferred-object/)) that is compatible to Ember.RSVP.Promise; will resolve if the request succeeds, reject otherwise
|
|
242
|
+
@protected
|
|
243
|
+
*/
|
|
244
|
+
makeRequest: function(url, data) {
|
|
245
|
+
if (!isSecureUrl(url)) {
|
|
246
|
+
Ember.Logger.warn('Credentials are transmitted via an insecure connection - use HTTPS to keep them secure.');
|
|
247
|
+
}
|
|
248
|
+
return Ember.$.ajax({
|
|
249
|
+
url: url,
|
|
250
|
+
type: 'POST',
|
|
251
|
+
data: data,
|
|
252
|
+
dataType: 'json',
|
|
253
|
+
contentType: 'application/x-www-form-urlencoded'
|
|
254
|
+
});
|
|
255
|
+
},
|
|
256
|
+
|
|
257
|
+
/**
|
|
258
|
+
@method scheduleAccessTokenRefresh
|
|
259
|
+
@private
|
|
260
|
+
*/
|
|
261
|
+
scheduleAccessTokenRefresh: function(expiresIn, expiresAt, refreshToken) {
|
|
262
|
+
var _this = this;
|
|
263
|
+
if (this.refreshAccessTokens) {
|
|
264
|
+
var now = (new Date()).getTime();
|
|
265
|
+
if (Ember.isEmpty(expiresAt) && !Ember.isEmpty(expiresIn)) {
|
|
266
|
+
expiresAt = new Date(now + expiresIn * 1000).getTime();
|
|
267
|
+
}
|
|
268
|
+
var offset = (Math.floor(Math.random() * 5) + 5) * 1000;
|
|
269
|
+
if (!Ember.isEmpty(refreshToken) && !Ember.isEmpty(expiresAt) && expiresAt > now - offset) {
|
|
270
|
+
Ember.run.cancel(this._refreshTokenTimeout);
|
|
271
|
+
delete this._refreshTokenTimeout;
|
|
272
|
+
if (!Ember.testing) {
|
|
273
|
+
this._refreshTokenTimeout = Ember.run.later(this, this.refreshAccessToken, expiresIn, refreshToken, expiresAt - now - offset);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
},
|
|
278
|
+
|
|
279
|
+
/**
|
|
280
|
+
@method refreshAccessToken
|
|
281
|
+
@private
|
|
282
|
+
*/
|
|
283
|
+
refreshAccessToken: function(expiresIn, refreshToken) {
|
|
284
|
+
var _this = this;
|
|
285
|
+
var data = { grant_type: 'refresh_token', refresh_token: refreshToken };
|
|
286
|
+
return new Ember.RSVP.Promise(function(resolve, reject) {
|
|
287
|
+
_this.makeRequest(_this.serverTokenEndpoint, data).then(function(response) {
|
|
288
|
+
Ember.run(function() {
|
|
289
|
+
expiresIn = response.expires_in || expiresIn;
|
|
290
|
+
refreshToken = response.refresh_token || refreshToken;
|
|
291
|
+
var expiresAt = _this.absolutizeExpirationTime(expiresIn);
|
|
292
|
+
var data = Ember.merge(response, { expires_in: expiresIn, expires_at: expiresAt, refresh_token: refreshToken });
|
|
293
|
+
_this.scheduleAccessTokenRefresh(expiresIn, null, refreshToken);
|
|
294
|
+
_this.trigger('sessionDataUpdated', data);
|
|
295
|
+
resolve(data);
|
|
296
|
+
});
|
|
297
|
+
}, function(xhr, status, error) {
|
|
298
|
+
Ember.Logger.warn('Access token could not be refreshed - server responded with ' + error + '.');
|
|
299
|
+
reject();
|
|
300
|
+
});
|
|
301
|
+
});
|
|
302
|
+
},
|
|
303
|
+
|
|
304
|
+
/**
|
|
305
|
+
@method absolutizeExpirationTime
|
|
306
|
+
@private
|
|
307
|
+
*/
|
|
308
|
+
absolutizeExpirationTime: function(expiresIn) {
|
|
309
|
+
if (!Ember.isEmpty(expiresIn)) {
|
|
310
|
+
return new Date((new Date().getTime()) + expiresIn * 1000).getTime();
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
});
|
|
314
|
+
});
|
|
315
|
+
define("simple-auth-oauth2/authorizers/oauth2",
|
|
316
|
+
["simple-auth/authorizers/base","simple-auth/utils/is-secure-url","exports"],
|
|
317
|
+
function(__dependency1__, __dependency2__, __exports__) {
|
|
318
|
+
"use strict";
|
|
319
|
+
var Base = __dependency1__["default"];
|
|
320
|
+
var isSecureUrl = __dependency2__["default"];
|
|
321
|
+
|
|
322
|
+
/**
|
|
323
|
+
Authorizer that conforms to OAuth 2
|
|
324
|
+
([RFC 6749](http://tools.ietf.org/html/rfc6749)) by sending a bearer token
|
|
325
|
+
([RFC 6749](http://tools.ietf.org/html/rfc6750)) in the request's
|
|
326
|
+
`Authorization` header.
|
|
327
|
+
|
|
328
|
+
_The factory for this authorizer is registered as
|
|
329
|
+
`'simple-auth-authorizer:oauth2-bearer'` in Ember's container._
|
|
330
|
+
|
|
331
|
+
@class OAuth2
|
|
332
|
+
@namespace SimpleAuth.Authorizers
|
|
333
|
+
@module simple-auth-devise/authorizers/oauth2
|
|
334
|
+
@extends Base
|
|
335
|
+
*/
|
|
336
|
+
__exports__["default"] = Base.extend({
|
|
337
|
+
/**
|
|
338
|
+
Authorizes an XHR request by sending the `access_token` property from the
|
|
339
|
+
session as a bearer token in the `Authorization` header:
|
|
340
|
+
|
|
341
|
+
```
|
|
342
|
+
Authorization: Bearer <access_token>
|
|
343
|
+
```
|
|
344
|
+
|
|
345
|
+
@method authorize
|
|
346
|
+
@param {jqXHR} jqXHR The XHR request to authorize (see http://api.jquery.com/jQuery.ajax/#jqXHR)
|
|
347
|
+
@param {Object} requestOptions The options as provided to the `$.ajax` method (see http://api.jquery.com/jQuery.ajaxPrefilter/)
|
|
348
|
+
*/
|
|
349
|
+
authorize: function(jqXHR, requestOptions) {
|
|
350
|
+
var accessToken = this.get('session.access_token');
|
|
351
|
+
if (this.get('session.isAuthenticated') && !Ember.isEmpty(accessToken)) {
|
|
352
|
+
if (!isSecureUrl(requestOptions.url)) {
|
|
353
|
+
Ember.Logger.warn('Credentials are transmitted via an insecure connection - use HTTPS to keep them secure.');
|
|
354
|
+
}
|
|
355
|
+
jqXHR.setRequestHeader('Authorization', 'Bearer ' + accessToken);
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
});
|
|
359
|
+
});
|
|
360
|
+
define("simple-auth-oauth2/ember",
|
|
361
|
+
["./initializer"],
|
|
362
|
+
function(__dependency1__) {
|
|
363
|
+
"use strict";
|
|
364
|
+
var initializer = __dependency1__["default"];
|
|
365
|
+
|
|
366
|
+
Ember.onLoad('Ember.Application', function(Application) {
|
|
367
|
+
Application.initializer(initializer);
|
|
368
|
+
});
|
|
369
|
+
});
|
|
370
|
+
define("simple-auth-oauth2/initializer",
|
|
371
|
+
["simple-auth-oauth2/authenticators/oauth2","simple-auth-oauth2/authorizers/oauth2","exports"],
|
|
372
|
+
function(__dependency1__, __dependency2__, __exports__) {
|
|
373
|
+
"use strict";
|
|
374
|
+
var Authenticator = __dependency1__["default"];
|
|
375
|
+
var Authorizer = __dependency2__["default"];
|
|
376
|
+
|
|
377
|
+
__exports__["default"] = {
|
|
378
|
+
name: 'simple-auth-oauth2',
|
|
379
|
+
before: 'simple-auth',
|
|
380
|
+
initialize: function(container, application) {
|
|
381
|
+
container.register('simple-auth-authorizer:oauth2-bearer', Authorizer);
|
|
382
|
+
container.register('simple-auth-authenticator:oauth2-password-grant', Authenticator);
|
|
383
|
+
}
|
|
384
|
+
};
|
|
385
|
+
});
|
|
386
|
+
})((typeof global !== 'undefined') ? global : window);
|