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.
Files changed (561) hide show
  1. checksums.yaml +7 -0
  2. data/.bowerrc +3 -0
  3. data/.gitignore +22 -0
  4. data/.rspec +2 -0
  5. data/.travis.yml +13 -0
  6. data/CHANGELOG.md +6 -0
  7. data/Gemfile +12 -0
  8. data/Gemfile.lock +392 -0
  9. data/LICENSE.txt +22 -0
  10. data/README.md +58 -0
  11. data/Rakefile +23 -0
  12. data/app/assets/images/dune/dashboard/logo@2x.png +0 -0
  13. data/app/assets/javascripts/adapters/channel_adapter.coffee +1 -0
  14. data/app/assets/javascripts/adapters/form_data.coffee +26 -0
  15. data/app/assets/javascripts/adapters/press_asset_adapter.coffee +1 -0
  16. data/app/assets/javascripts/configs.coffee +10 -0
  17. data/app/assets/javascripts/controllers/.gitkeep +0 -0
  18. data/app/assets/javascripts/controllers/channels.coffee +40 -0
  19. data/app/assets/javascripts/controllers/contributions.coffee +26 -0
  20. data/app/assets/javascripts/controllers/press_assets.coffee +24 -0
  21. data/app/assets/javascripts/controllers/projects.coffee +36 -0
  22. data/app/assets/javascripts/controllers/sessions.coffee +2 -0
  23. data/app/assets/javascripts/controllers/tags.coffee +24 -0
  24. data/app/assets/javascripts/controllers/users.coffee +8 -0
  25. data/app/assets/javascripts/dashboard.coffee +5 -0
  26. data/app/assets/javascripts/dune-dashboard-application.js +16 -0
  27. data/app/assets/javascripts/dune-dashboard-libs.js +25 -0
  28. data/app/assets/javascripts/dune-dashboard-templates.js +1 -0
  29. data/app/assets/javascripts/helpers/daterangepicker.coffee +1 -0
  30. data/app/assets/javascripts/helpers/format-date.coffee +5 -0
  31. data/app/assets/javascripts/helpers/loading.coffee +14 -0
  32. data/app/assets/javascripts/helpers/number-to-currency.coffee +5 -0
  33. data/app/assets/javascripts/helpers/pagination.coffee +1 -0
  34. data/app/assets/javascripts/helpers/show-boolean.coffee +5 -0
  35. data/app/assets/javascripts/i18n/translations_en.js +165 -0
  36. data/app/assets/javascripts/initializers/authentication.coffee +50 -0
  37. data/app/assets/javascripts/mixins/modal-controller.coffee +7 -0
  38. data/app/assets/javascripts/mixins/modal-view.coffee +15 -0
  39. data/app/assets/javascripts/mixins/paginable.coffee +25 -0
  40. data/app/assets/javascripts/mixins/searchable.coffee +58 -0
  41. data/app/assets/javascripts/models/.gitkeep +0 -0
  42. data/app/assets/javascripts/models/channel.coffee +25 -0
  43. data/app/assets/javascripts/models/contributions.coffee +15 -0
  44. data/app/assets/javascripts/models/press_asset.coffee +5 -0
  45. data/app/assets/javascripts/models/project.coffee +16 -0
  46. data/app/assets/javascripts/models/reward.coffee +4 -0
  47. data/app/assets/javascripts/models/tag.coffee +4 -0
  48. data/app/assets/javascripts/models/user.coffee +13 -0
  49. data/app/assets/javascripts/router.coffee +36 -0
  50. data/app/assets/javascripts/routes/.gitkeep +0 -0
  51. data/app/assets/javascripts/routes/application.coffee +35 -0
  52. data/app/assets/javascripts/routes/channels-edit.coffee +4 -0
  53. data/app/assets/javascripts/routes/channels-new.coffee +4 -0
  54. data/app/assets/javascripts/routes/channels.coffee +21 -0
  55. data/app/assets/javascripts/routes/contributions.coffee +29 -0
  56. data/app/assets/javascripts/routes/index.coffee +4 -0
  57. data/app/assets/javascripts/routes/press_assets-edit.coffee +4 -0
  58. data/app/assets/javascripts/routes/press_assets-new.coffee +5 -0
  59. data/app/assets/javascripts/routes/press_assets.coffee +13 -0
  60. data/app/assets/javascripts/routes/projects.coffee +23 -0
  61. data/app/assets/javascripts/routes/sessions.coffee +3 -0
  62. data/app/assets/javascripts/routes/tags-edit.coffee +4 -0
  63. data/app/assets/javascripts/routes/tags-new.coffee +5 -0
  64. data/app/assets/javascripts/routes/tags.coffee +15 -0
  65. data/app/assets/javascripts/routes/users.coffee +17 -0
  66. data/app/assets/javascripts/serializers/channel.coffee +10 -0
  67. data/app/assets/javascripts/serializers/file.coffee +6 -0
  68. data/app/assets/javascripts/serializers/object.coffee +6 -0
  69. data/app/assets/javascripts/serializers/project.coffee +4 -0
  70. data/app/assets/javascripts/store.coffee +5 -0
  71. data/app/assets/javascripts/templates/.gitkeep +0 -0
  72. data/app/assets/javascripts/templates/channels/_form.emblem +256 -0
  73. data/app/assets/javascripts/templates/channels/edit.emblem +1 -0
  74. data/app/assets/javascripts/templates/channels/index.emblem +66 -0
  75. data/app/assets/javascripts/templates/channels/new.emblem +1 -0
  76. data/app/assets/javascripts/templates/channels/search-form.emblem +13 -0
  77. data/app/assets/javascripts/templates/contributions/index.emblem +111 -0
  78. data/app/assets/javascripts/templates/contributions/search-form.emblem +27 -0
  79. data/app/assets/javascripts/templates/contributions/show.emblem +79 -0
  80. data/app/assets/javascripts/templates/daterangepicker.emblem +5 -0
  81. data/app/assets/javascripts/templates/layouts/application.emblem +19 -0
  82. data/app/assets/javascripts/templates/layouts/header.emblem +25 -0
  83. data/app/assets/javascripts/templates/layouts/sidebar.emblem +32 -0
  84. data/app/assets/javascripts/templates/pagination.emblem +10 -0
  85. data/app/assets/javascripts/templates/press_assets/_form.emblem +33 -0
  86. data/app/assets/javascripts/templates/press_assets/edit.emblem +1 -0
  87. data/app/assets/javascripts/templates/press_assets/index.emblem +45 -0
  88. data/app/assets/javascripts/templates/press_assets/new.emblem +1 -0
  89. data/app/assets/javascripts/templates/projects/index.emblem +119 -0
  90. data/app/assets/javascripts/templates/projects/search-form.emblem +19 -0
  91. data/app/assets/javascripts/templates/search-tab.emblem +6 -0
  92. data/app/assets/javascripts/templates/sessions/new.emblem +17 -0
  93. data/app/assets/javascripts/templates/tags/_form.emblem +24 -0
  94. data/app/assets/javascripts/templates/tags/edit.emblem +1 -0
  95. data/app/assets/javascripts/templates/tags/index.emblem +46 -0
  96. data/app/assets/javascripts/templates/tags/new.emblem +1 -0
  97. data/app/assets/javascripts/templates/users/index.emblem +51 -0
  98. data/app/assets/javascripts/templates/users/search-form.emblem +13 -0
  99. data/app/assets/javascripts/views/auto-save-checkbox.coffee +14 -0
  100. data/app/assets/javascripts/views/contributions/show.coffee +1 -0
  101. data/app/assets/javascripts/views/daterangepicker.coffee +60 -0
  102. data/app/assets/javascripts/views/file.coffee +7 -0
  103. data/app/assets/javascripts/views/layouts/header.coffee +23 -0
  104. data/app/assets/javascripts/views/layouts/sidebar.coffee +6 -0
  105. data/app/assets/javascripts/views/page-title.coffee +45 -0
  106. data/app/assets/javascripts/views/pagination.coffee +51 -0
  107. data/app/assets/javascripts/views/projects/index.coffee +5 -0
  108. data/app/assets/javascripts/views/search-tab.coffee +24 -0
  109. data/app/assets/stylesheets/core/core.sass +299 -0
  110. data/app/assets/stylesheets/core/mixins.sass +83 -0
  111. data/app/assets/stylesheets/core/settings.sass +75 -0
  112. data/app/assets/stylesheets/dune-dashboard-application.sass +12 -0
  113. data/app/assets/stylesheets/modules/alerts.sass +21 -0
  114. data/app/assets/stylesheets/modules/avatar.sass +13 -0
  115. data/app/assets/stylesheets/modules/boxes.sass +274 -0
  116. data/app/assets/stylesheets/modules/buttons.sass +160 -0
  117. data/app/assets/stylesheets/modules/dl-details.sass +13 -0
  118. data/app/assets/stylesheets/modules/forms.sass +53 -0
  119. data/app/assets/stylesheets/modules/generic.sass +9 -0
  120. data/app/assets/stylesheets/modules/header.sass +153 -0
  121. data/app/assets/stylesheets/modules/labels.sass +3 -0
  122. data/app/assets/stylesheets/modules/navs.sass +98 -0
  123. data/app/assets/stylesheets/modules/pagination.sass +19 -0
  124. data/app/assets/stylesheets/modules/sidebar.sass +147 -0
  125. data/app/assets/stylesheets/modules/small-box.sass +78 -0
  126. data/app/assets/stylesheets/pages/login.sass +42 -0
  127. data/app/controllers/dune/dashboard/ember_controller.rb +7 -0
  128. data/app/views/layouts/dune/dashboard/application.html.erb +15 -0
  129. data/bower.json +28 -0
  130. data/config/ember-i18n.yml +2 -0
  131. data/config/ember_locales/channels.en.yml +49 -0
  132. data/config/ember_locales/contributions.en.yml +42 -0
  133. data/config/ember_locales/en.yml +1 -0
  134. data/config/ember_locales/layouts.en.yml +16 -0
  135. data/config/ember_locales/press_assets.en.yml +14 -0
  136. data/config/ember_locales/projects.en.yml +33 -0
  137. data/config/ember_locales/sessions.en.yml +11 -0
  138. data/config/ember_locales/tags.en.yml +12 -0
  139. data/config/ember_locales/titles.en.yml +22 -0
  140. data/config/ember_locales/users.en.yml +12 -0
  141. data/config/ember_locales/words.en.yml +12 -0
  142. data/config/routes.rb +4 -0
  143. data/dune-dashboard.gemspec +28 -0
  144. data/lib/dune/dashboard.rb +11 -0
  145. data/lib/dune/dashboard/engine.rb +12 -0
  146. data/lib/dune/dashboard/i18n.rb +108 -0
  147. data/lib/dune/dashboard/version.rb +5 -0
  148. data/spec/dummy/README.rdoc +28 -0
  149. data/spec/dummy/Rakefile +6 -0
  150. data/spec/dummy/app/assets/images/.keep +0 -0
  151. data/spec/dummy/app/assets/javascripts/application.js +13 -0
  152. data/spec/dummy/app/assets/stylesheets/application.css +13 -0
  153. data/spec/dummy/app/controllers/application_controller.rb +5 -0
  154. data/spec/dummy/app/controllers/concerns/.keep +0 -0
  155. data/spec/dummy/app/helpers/application_helper.rb +2 -0
  156. data/spec/dummy/app/mailers/.keep +0 -0
  157. data/spec/dummy/app/models/.keep +0 -0
  158. data/spec/dummy/app/models/concerns/.keep +0 -0
  159. data/spec/dummy/app/views/layouts/application.html.erb +14 -0
  160. data/spec/dummy/bin/bundle +3 -0
  161. data/spec/dummy/bin/rails +4 -0
  162. data/spec/dummy/bin/rake +4 -0
  163. data/spec/dummy/config.ru +4 -0
  164. data/spec/dummy/config/application.rb +30 -0
  165. data/spec/dummy/config/boot.rb +5 -0
  166. data/spec/dummy/config/environment.rb +5 -0
  167. data/spec/dummy/config/environments/development.rb +29 -0
  168. data/spec/dummy/config/environments/production.rb +80 -0
  169. data/spec/dummy/config/environments/test.rb +38 -0
  170. data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
  171. data/spec/dummy/config/initializers/filter_parameter_logging.rb +4 -0
  172. data/spec/dummy/config/initializers/inflections.rb +16 -0
  173. data/spec/dummy/config/initializers/mime_types.rb +5 -0
  174. data/spec/dummy/config/initializers/secret_token.rb +12 -0
  175. data/spec/dummy/config/initializers/session_store.rb +3 -0
  176. data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
  177. data/spec/dummy/config/locales/en.yml +23 -0
  178. data/spec/dummy/config/routes.rb +3 -0
  179. data/spec/dummy/lib/assets/.keep +0 -0
  180. data/spec/dummy/log/.keep +0 -0
  181. data/spec/dummy/public/404.html +58 -0
  182. data/spec/dummy/public/422.html +58 -0
  183. data/spec/dummy/public/500.html +57 -0
  184. data/spec/dummy/public/favicon.ico +0 -0
  185. data/spec/javascripts/controllers/channels_spec.coffee +16 -0
  186. data/spec/javascripts/controllers/press_assets_spec.coffee +5 -0
  187. data/spec/javascripts/controllers/projects_spec.coffee +16 -0
  188. data/spec/javascripts/controllers/users_spec.coffee +16 -0
  189. data/spec/javascripts/fixtures/channels.coffee +49 -0
  190. data/spec/javascripts/fixtures/contributions.coffee +46 -0
  191. data/spec/javascripts/fixtures/press_assets.coffee +15 -0
  192. data/spec/javascripts/fixtures/projects.coffee +108 -0
  193. data/spec/javascripts/fixtures/tags.coffee +15 -0
  194. data/spec/javascripts/fixtures/users.coffee +26 -0
  195. data/spec/javascripts/helpers/auththentication.coffee +11 -0
  196. data/spec/javascripts/integration/channels_spec.coffee +109 -0
  197. data/spec/javascripts/integration/contributions_spec.coffee +108 -0
  198. data/spec/javascripts/integration/press_assets_spec.coffee +66 -0
  199. data/spec/javascripts/integration/projects_spec.coffee +110 -0
  200. data/spec/javascripts/integration/sessions_spec.coffee +71 -0
  201. data/spec/javascripts/integration/tags_spec.coffee +65 -0
  202. data/spec/javascripts/integration/users_spec.coffee +108 -0
  203. data/spec/javascripts/models/channel_spec.coffee +4 -0
  204. data/spec/javascripts/models/contribution_spec.coffee +4 -0
  205. data/spec/javascripts/models/press_asset_spec.coffee +5 -0
  206. data/spec/javascripts/models/project_spec.coffee +4 -0
  207. data/spec/javascripts/models/reward_spec.coffee +4 -0
  208. data/spec/javascripts/models/tag_spec.coffee +4 -0
  209. data/spec/javascripts/models/user_spec.coffee +4 -0
  210. data/spec/javascripts/spec_helper.coffee +56 -0
  211. data/spec/javascripts/support/jquery.mockjax.js +598 -0
  212. data/spec/teaspoon_env.rb +183 -0
  213. data/vendor/assets/components/cldr/.bower.json +14 -0
  214. data/vendor/assets/components/cldr/README.md +47 -0
  215. data/vendor/assets/components/cldr/plurals.js +240 -0
  216. data/vendor/assets/components/ember-i18n/.bower.json +46 -0
  217. data/vendor/assets/components/ember-i18n/CONTRIBUTING.md +13 -0
  218. data/vendor/assets/components/ember-i18n/Changelog.md +82 -0
  219. data/vendor/assets/components/ember-i18n/LICENSE +10 -0
  220. data/vendor/assets/components/ember-i18n/README.md +148 -0
  221. data/vendor/assets/components/ember-i18n/VERSION +1 -0
  222. data/vendor/assets/components/ember-i18n/bower.json +34 -0
  223. data/vendor/assets/components/ember-i18n/lib/i18n.js +215 -0
  224. data/vendor/assets/components/ember-i18n/package.json +27 -0
  225. data/vendor/assets/components/ember-i18n/script/buildSuite.js +34 -0
  226. data/vendor/assets/components/ember-i18n/script/fetch_vendor.js +66 -0
  227. data/vendor/assets/components/ember-i18n/script/run.js +24 -0
  228. data/vendor/assets/components/ember-simple-auth/.bower.json +31 -0
  229. data/vendor/assets/components/ember-simple-auth/LICENSE +20 -0
  230. data/vendor/assets/components/ember-simple-auth/README.md +15 -0
  231. data/vendor/assets/components/ember-simple-auth/bower.json +21 -0
  232. data/vendor/assets/components/ember-simple-auth/simple-auth-cookie-store.amd.js +220 -0
  233. data/vendor/assets/components/ember-simple-auth/simple-auth-cookie-store.js +284 -0
  234. data/vendor/assets/components/ember-simple-auth/simple-auth-devise.amd.js +243 -0
  235. data/vendor/assets/components/ember-simple-auth/simple-auth-devise.js +312 -0
  236. data/vendor/assets/components/ember-simple-auth/simple-auth-oauth2.amd.js +386 -0
  237. data/vendor/assets/components/ember-simple-auth/simple-auth-oauth2.js +455 -0
  238. data/vendor/assets/components/ember-simple-auth/simple-auth-testing.amd.js +79 -0
  239. data/vendor/assets/components/ember-simple-auth/simple-auth-testing.js +137 -0
  240. data/vendor/assets/components/ember-simple-auth/simple-auth-torii.amd.js +142 -0
  241. data/vendor/assets/components/ember-simple-auth/simple-auth-torii.js +199 -0
  242. data/vendor/assets/components/ember-simple-auth/simple-auth.amd.js +1450 -0
  243. data/vendor/assets/components/ember-simple-auth/simple-auth.js +1548 -0
  244. data/vendor/assets/components/ember/.bower.json +21 -0
  245. data/vendor/assets/components/ember/.gitignore +5 -0
  246. data/vendor/assets/components/ember/Makefile +9 -0
  247. data/vendor/assets/components/ember/README.md +12 -0
  248. data/vendor/assets/components/ember/bower.json +11 -0
  249. data/vendor/assets/components/ember/component.json +13 -0
  250. data/vendor/assets/components/ember/composer.json +27 -0
  251. data/vendor/assets/components/ember/ember-template-compiler.js +336 -0
  252. data/vendor/assets/components/ember/ember.js +46762 -0
  253. data/vendor/assets/components/ember/ember.min.js +20 -0
  254. data/vendor/assets/components/ember/ember.prod.js +46319 -0
  255. data/vendor/assets/components/ember/package.json +11 -0
  256. data/vendor/assets/components/handlebars/.bower.json +16 -0
  257. data/vendor/assets/components/handlebars/.gitignore +2 -0
  258. data/vendor/assets/components/handlebars/README.md +11 -0
  259. data/vendor/assets/components/handlebars/bower.json +6 -0
  260. data/vendor/assets/components/handlebars/component.json +9 -0
  261. data/vendor/assets/components/handlebars/composer.json +35 -0
  262. data/vendor/assets/components/handlebars/handlebars-source.gemspec +21 -0
  263. data/vendor/assets/components/handlebars/handlebars.amd.js +2719 -0
  264. data/vendor/assets/components/handlebars/handlebars.amd.min.js +28 -0
  265. data/vendor/assets/components/handlebars/handlebars.js +2746 -0
  266. data/vendor/assets/components/handlebars/handlebars.js.nuspec +17 -0
  267. data/vendor/assets/components/handlebars/handlebars.min.js +28 -0
  268. data/vendor/assets/components/handlebars/handlebars.runtime.amd.js +515 -0
  269. data/vendor/assets/components/handlebars/handlebars.runtime.amd.min.js +27 -0
  270. data/vendor/assets/components/handlebars/handlebars.runtime.js +530 -0
  271. data/vendor/assets/components/handlebars/handlebars.runtime.min.js +27 -0
  272. data/vendor/assets/components/handlebars/lib/handlebars/source.rb +11 -0
  273. data/vendor/assets/components/jquery/.bower.json +37 -0
  274. data/vendor/assets/components/jquery/MIT-LICENSE.txt +21 -0
  275. data/vendor/assets/components/jquery/bower.json +27 -0
  276. data/vendor/assets/components/jquery/dist/jquery.js +9111 -0
  277. data/vendor/assets/components/jquery/dist/jquery.min.js +5 -0
  278. data/vendor/assets/components/jquery/dist/jquery.min.map +1 -0
  279. data/vendor/assets/components/jquery/src/ajax.js +806 -0
  280. data/vendor/assets/components/jquery/src/ajax/jsonp.js +89 -0
  281. data/vendor/assets/components/jquery/src/ajax/load.js +75 -0
  282. data/vendor/assets/components/jquery/src/ajax/parseJSON.js +13 -0
  283. data/vendor/assets/components/jquery/src/ajax/parseXML.js +28 -0
  284. data/vendor/assets/components/jquery/src/ajax/script.js +64 -0
  285. data/vendor/assets/components/jquery/src/ajax/var/nonce.js +5 -0
  286. data/vendor/assets/components/jquery/src/ajax/var/rquery.js +3 -0
  287. data/vendor/assets/components/jquery/src/ajax/xhr.js +130 -0
  288. data/vendor/assets/components/jquery/src/attributes.js +11 -0
  289. data/vendor/assets/components/jquery/src/attributes/attr.js +143 -0
  290. data/vendor/assets/components/jquery/src/attributes/classes.js +158 -0
  291. data/vendor/assets/components/jquery/src/attributes/prop.js +96 -0
  292. data/vendor/assets/components/jquery/src/attributes/support.js +35 -0
  293. data/vendor/assets/components/jquery/src/attributes/val.js +153 -0
  294. data/vendor/assets/components/jquery/src/callbacks.js +205 -0
  295. data/vendor/assets/components/jquery/src/core.js +500 -0
  296. data/vendor/assets/components/jquery/src/core/access.js +60 -0
  297. data/vendor/assets/components/jquery/src/core/init.js +123 -0
  298. data/vendor/assets/components/jquery/src/core/parseHTML.js +39 -0
  299. data/vendor/assets/components/jquery/src/core/ready.js +96 -0
  300. data/vendor/assets/components/jquery/src/core/var/rsingleTag.js +4 -0
  301. data/vendor/assets/components/jquery/src/css.js +455 -0
  302. data/vendor/assets/components/jquery/src/css/addGetHookIf.js +24 -0
  303. data/vendor/assets/components/jquery/src/css/curCSS.js +57 -0
  304. data/vendor/assets/components/jquery/src/css/defaultDisplay.js +69 -0
  305. data/vendor/assets/components/jquery/src/css/hiddenVisibleSelectors.js +15 -0
  306. data/vendor/assets/components/jquery/src/css/support.js +83 -0
  307. data/vendor/assets/components/jquery/src/css/swap.js +28 -0
  308. data/vendor/assets/components/jquery/src/css/var/cssExpand.js +3 -0
  309. data/vendor/assets/components/jquery/src/css/var/getStyles.js +5 -0
  310. data/vendor/assets/components/jquery/src/css/var/isHidden.js +13 -0
  311. data/vendor/assets/components/jquery/src/css/var/rmargin.js +3 -0
  312. data/vendor/assets/components/jquery/src/css/var/rnumnonpx.js +5 -0
  313. data/vendor/assets/components/jquery/src/data.js +175 -0
  314. data/vendor/assets/components/jquery/src/data/Data.js +181 -0
  315. data/vendor/assets/components/jquery/src/data/accepts.js +20 -0
  316. data/vendor/assets/components/jquery/src/data/var/data_priv.js +5 -0
  317. data/vendor/assets/components/jquery/src/data/var/data_user.js +5 -0
  318. data/vendor/assets/components/jquery/src/deferred.js +149 -0
  319. data/vendor/assets/components/jquery/src/deprecated.js +13 -0
  320. data/vendor/assets/components/jquery/src/dimensions.js +50 -0
  321. data/vendor/assets/components/jquery/src/effects.js +642 -0
  322. data/vendor/assets/components/jquery/src/effects/Tween.js +114 -0
  323. data/vendor/assets/components/jquery/src/effects/animatedSelector.js +13 -0
  324. data/vendor/assets/components/jquery/src/event.js +859 -0
  325. data/vendor/assets/components/jquery/src/event/alias.js +39 -0
  326. data/vendor/assets/components/jquery/src/event/support.js +9 -0
  327. data/vendor/assets/components/jquery/src/exports/amd.js +18 -0
  328. data/vendor/assets/components/jquery/src/exports/global.js +32 -0
  329. data/vendor/assets/components/jquery/src/intro.js +44 -0
  330. data/vendor/assets/components/jquery/src/jquery.js +36 -0
  331. data/vendor/assets/components/jquery/src/manipulation.js +583 -0
  332. data/vendor/assets/components/jquery/src/manipulation/_evalUrl.js +18 -0
  333. data/vendor/assets/components/jquery/src/manipulation/support.js +24 -0
  334. data/vendor/assets/components/jquery/src/manipulation/var/rcheckableType.js +3 -0
  335. data/vendor/assets/components/jquery/src/offset.js +204 -0
  336. data/vendor/assets/components/jquery/src/outro.js +1 -0
  337. data/vendor/assets/components/jquery/src/queue.js +142 -0
  338. data/vendor/assets/components/jquery/src/queue/delay.js +22 -0
  339. data/vendor/assets/components/jquery/src/selector-native.js +171 -0
  340. data/vendor/assets/components/jquery/src/selector-sizzle.js +14 -0
  341. data/vendor/assets/components/jquery/src/selector.js +1 -0
  342. data/vendor/assets/components/jquery/src/serialize.js +111 -0
  343. data/vendor/assets/components/jquery/src/sizzle/dist/sizzle.js +2015 -0
  344. data/vendor/assets/components/jquery/src/sizzle/dist/sizzle.min.js +3 -0
  345. data/vendor/assets/components/jquery/src/sizzle/dist/sizzle.min.map +1 -0
  346. data/vendor/assets/components/jquery/src/traversing.js +200 -0
  347. data/vendor/assets/components/jquery/src/traversing/findFilter.js +100 -0
  348. data/vendor/assets/components/jquery/src/traversing/var/rneedsContext.js +6 -0
  349. data/vendor/assets/components/jquery/src/var/arr.js +3 -0
  350. data/vendor/assets/components/jquery/src/var/class2type.js +4 -0
  351. data/vendor/assets/components/jquery/src/var/concat.js +5 -0
  352. data/vendor/assets/components/jquery/src/var/hasOwn.js +5 -0
  353. data/vendor/assets/components/jquery/src/var/indexOf.js +5 -0
  354. data/vendor/assets/components/jquery/src/var/pnum.js +3 -0
  355. data/vendor/assets/components/jquery/src/var/push.js +5 -0
  356. data/vendor/assets/components/jquery/src/var/rnotwhite.js +3 -0
  357. data/vendor/assets/components/jquery/src/var/slice.js +5 -0
  358. data/vendor/assets/components/jquery/src/var/strundefined.js +3 -0
  359. data/vendor/assets/components/jquery/src/var/support.js +4 -0
  360. data/vendor/assets/components/jquery/src/var/toString.js +5 -0
  361. data/vendor/assets/components/jquery/src/var/trim.js +3 -0
  362. data/vendor/assets/components/jquery/src/wrap.js +78 -0
  363. data/vendor/assets/components/moment/.bower.json +30 -0
  364. data/vendor/assets/components/moment/LICENSE +22 -0
  365. data/vendor/assets/components/moment/bower.json +20 -0
  366. data/vendor/assets/components/moment/lang/ar-ma.js +56 -0
  367. data/vendor/assets/components/moment/lang/ar-sa.js +96 -0
  368. data/vendor/assets/components/moment/lang/ar.js +97 -0
  369. data/vendor/assets/components/moment/lang/az.js +102 -0
  370. data/vendor/assets/components/moment/lang/bg.js +86 -0
  371. data/vendor/assets/components/moment/lang/bn.js +106 -0
  372. data/vendor/assets/components/moment/lang/br.js +107 -0
  373. data/vendor/assets/components/moment/lang/bs.js +139 -0
  374. data/vendor/assets/components/moment/lang/ca.js +66 -0
  375. data/vendor/assets/components/moment/lang/cs.js +155 -0
  376. data/vendor/assets/components/moment/lang/cv.js +59 -0
  377. data/vendor/assets/components/moment/lang/cy.js +77 -0
  378. data/vendor/assets/components/moment/lang/da.js +56 -0
  379. data/vendor/assets/components/moment/lang/de-at.js +72 -0
  380. data/vendor/assets/components/moment/lang/de.js +71 -0
  381. data/vendor/assets/components/moment/lang/el.js +90 -0
  382. data/vendor/assets/components/moment/lang/en-au.js +62 -0
  383. data/vendor/assets/components/moment/lang/en-ca.js +59 -0
  384. data/vendor/assets/components/moment/lang/en-gb.js +63 -0
  385. data/vendor/assets/components/moment/lang/eo.js +65 -0
  386. data/vendor/assets/components/moment/lang/es.js +75 -0
  387. data/vendor/assets/components/moment/lang/et.js +76 -0
  388. data/vendor/assets/components/moment/lang/eu.js +60 -0
  389. data/vendor/assets/components/moment/lang/fa.js +97 -0
  390. data/vendor/assets/components/moment/lang/fi.js +103 -0
  391. data/vendor/assets/components/moment/lang/fo.js +56 -0
  392. data/vendor/assets/components/moment/lang/fr-ca.js +54 -0
  393. data/vendor/assets/components/moment/lang/fr.js +58 -0
  394. data/vendor/assets/components/moment/lang/gl.js +71 -0
  395. data/vendor/assets/components/moment/lang/he.js +77 -0
  396. data/vendor/assets/components/moment/lang/hi.js +105 -0
  397. data/vendor/assets/components/moment/lang/hr.js +140 -0
  398. data/vendor/assets/components/moment/lang/hu.js +105 -0
  399. data/vendor/assets/components/moment/lang/hy-am.js +113 -0
  400. data/vendor/assets/components/moment/lang/id.js +67 -0
  401. data/vendor/assets/components/moment/lang/is.js +124 -0
  402. data/vendor/assets/components/moment/lang/it.js +59 -0
  403. data/vendor/assets/components/moment/lang/ja.js +58 -0
  404. data/vendor/assets/components/moment/lang/ka.js +108 -0
  405. data/vendor/assets/components/moment/lang/km.js +55 -0
  406. data/vendor/assets/components/moment/lang/ko.js +63 -0
  407. data/vendor/assets/components/moment/lang/lb.js +160 -0
  408. data/vendor/assets/components/moment/lang/lt.js +118 -0
  409. data/vendor/assets/components/moment/lang/lv.js +77 -0
  410. data/vendor/assets/components/moment/lang/mk.js +86 -0
  411. data/vendor/assets/components/moment/lang/ml.js +64 -0
  412. data/vendor/assets/components/moment/lang/mr.js +104 -0
  413. data/vendor/assets/components/moment/lang/ms-my.js +66 -0
  414. data/vendor/assets/components/moment/lang/nb.js +57 -0
  415. data/vendor/assets/components/moment/lang/ne.js +105 -0
  416. data/vendor/assets/components/moment/lang/nl.js +67 -0
  417. data/vendor/assets/components/moment/lang/nn.js +56 -0
  418. data/vendor/assets/components/moment/lang/pl.js +98 -0
  419. data/vendor/assets/components/moment/lang/pt-br.js +56 -0
  420. data/vendor/assets/components/moment/lang/pt.js +60 -0
  421. data/vendor/assets/components/moment/lang/ro.js +72 -0
  422. data/vendor/assets/components/moment/lang/ru.js +166 -0
  423. data/vendor/assets/components/moment/lang/sk.js +156 -0
  424. data/vendor/assets/components/moment/lang/sl.js +144 -0
  425. data/vendor/assets/components/moment/lang/sq.js +61 -0
  426. data/vendor/assets/components/moment/lang/sr-cyrl.js +106 -0
  427. data/vendor/assets/components/moment/lang/sr.js +106 -0
  428. data/vendor/assets/components/moment/lang/sv.js +63 -0
  429. data/vendor/assets/components/moment/lang/ta.js +112 -0
  430. data/vendor/assets/components/moment/lang/th.js +58 -0
  431. data/vendor/assets/components/moment/lang/tl-ph.js +58 -0
  432. data/vendor/assets/components/moment/lang/tr.js +93 -0
  433. data/vendor/assets/components/moment/lang/tzm-latn.js +55 -0
  434. data/vendor/assets/components/moment/lang/tzm.js +55 -0
  435. data/vendor/assets/components/moment/lang/uk.js +157 -0
  436. data/vendor/assets/components/moment/lang/uz.js +55 -0
  437. data/vendor/assets/components/moment/lang/vi.js +62 -0
  438. data/vendor/assets/components/moment/lang/zh-cn.js +108 -0
  439. data/vendor/assets/components/moment/lang/zh-tw.js +84 -0
  440. data/vendor/assets/components/moment/min/langs.js +6426 -0
  441. data/vendor/assets/components/moment/min/langs.min.js +4 -0
  442. data/vendor/assets/components/moment/min/moment-with-langs.js +8521 -0
  443. data/vendor/assets/components/moment/min/moment-with-langs.min.js +9 -0
  444. data/vendor/assets/components/moment/min/moment.min.js +6 -0
  445. data/vendor/assets/components/moment/moment.js +2610 -0
  446. data/vendor/assets/components/moment/readme.md +388 -0
  447. data/vendor/assets/components/numeral/.bower.json +28 -0
  448. data/vendor/assets/components/numeral/.gitignore +29 -0
  449. data/vendor/assets/components/numeral/.travis.yml +7 -0
  450. data/vendor/assets/components/numeral/Gruntfile.js +91 -0
  451. data/vendor/assets/components/numeral/LICENSE +22 -0
  452. data/vendor/assets/components/numeral/README.md +213 -0
  453. data/vendor/assets/components/numeral/bower.json +16 -0
  454. data/vendor/assets/components/numeral/component.json +16 -0
  455. data/vendor/assets/components/numeral/languages.js +989 -0
  456. data/vendor/assets/components/numeral/languages/be-nl.js +35 -0
  457. data/vendor/assets/components/numeral/languages/chs.js +34 -0
  458. data/vendor/assets/components/numeral/languages/cs.js +34 -0
  459. data/vendor/assets/components/numeral/languages/da-dk.js +34 -0
  460. data/vendor/assets/components/numeral/languages/de-ch.js +34 -0
  461. data/vendor/assets/components/numeral/languages/de.js +34 -0
  462. data/vendor/assets/components/numeral/languages/en-gb.js +38 -0
  463. data/vendor/assets/components/numeral/languages/es-ES.js +39 -0
  464. data/vendor/assets/components/numeral/languages/es.js +39 -0
  465. data/vendor/assets/components/numeral/languages/et.js +37 -0
  466. data/vendor/assets/components/numeral/languages/fi.js +34 -0
  467. data/vendor/assets/components/numeral/languages/fr-CA.js +34 -0
  468. data/vendor/assets/components/numeral/languages/fr-ch.js +34 -0
  469. data/vendor/assets/components/numeral/languages/fr.js +34 -0
  470. data/vendor/assets/components/numeral/languages/hu.js +34 -0
  471. data/vendor/assets/components/numeral/languages/it.js +34 -0
  472. data/vendor/assets/components/numeral/languages/ja.js +34 -0
  473. data/vendor/assets/components/numeral/languages/nl-nl.js +35 -0
  474. data/vendor/assets/components/numeral/languages/pl.js +34 -0
  475. data/vendor/assets/components/numeral/languages/pt-br.js +34 -0
  476. data/vendor/assets/components/numeral/languages/pt-pt.js +34 -0
  477. data/vendor/assets/components/numeral/languages/ru-UA.js +35 -0
  478. data/vendor/assets/components/numeral/languages/ru.js +37 -0
  479. data/vendor/assets/components/numeral/languages/sk.js +34 -0
  480. data/vendor/assets/components/numeral/languages/th.js +34 -0
  481. data/vendor/assets/components/numeral/languages/tr.js +67 -0
  482. data/vendor/assets/components/numeral/languages/uk-UA.js +35 -0
  483. data/vendor/assets/components/numeral/min/languages.min.js +129 -0
  484. data/vendor/assets/components/numeral/min/languages/be-nl.min.js +6 -0
  485. data/vendor/assets/components/numeral/min/languages/chs.min.js +6 -0
  486. data/vendor/assets/components/numeral/min/languages/cs.min.js +6 -0
  487. data/vendor/assets/components/numeral/min/languages/da-dk.min.js +6 -0
  488. data/vendor/assets/components/numeral/min/languages/de-ch.min.js +6 -0
  489. data/vendor/assets/components/numeral/min/languages/de.min.js +6 -0
  490. data/vendor/assets/components/numeral/min/languages/en-gb.min.js +6 -0
  491. data/vendor/assets/components/numeral/min/languages/es-ES.min.js +6 -0
  492. data/vendor/assets/components/numeral/min/languages/es.min.js +6 -0
  493. data/vendor/assets/components/numeral/min/languages/et.min.js +9 -0
  494. data/vendor/assets/components/numeral/min/languages/fi.min.js +6 -0
  495. data/vendor/assets/components/numeral/min/languages/fr-CA.min.js +6 -0
  496. data/vendor/assets/components/numeral/min/languages/fr-ch.min.js +6 -0
  497. data/vendor/assets/components/numeral/min/languages/fr.min.js +6 -0
  498. data/vendor/assets/components/numeral/min/languages/hu.min.js +6 -0
  499. data/vendor/assets/components/numeral/min/languages/it.min.js +6 -0
  500. data/vendor/assets/components/numeral/min/languages/ja.min.js +6 -0
  501. data/vendor/assets/components/numeral/min/languages/nl-nl.min.js +6 -0
  502. data/vendor/assets/components/numeral/min/languages/pl.min.js +6 -0
  503. data/vendor/assets/components/numeral/min/languages/pt-br.min.js +6 -0
  504. data/vendor/assets/components/numeral/min/languages/pt-pt.min.js +6 -0
  505. data/vendor/assets/components/numeral/min/languages/ru-UA.min.js +1 -0
  506. data/vendor/assets/components/numeral/min/languages/ru.min.js +6 -0
  507. data/vendor/assets/components/numeral/min/languages/sk.min.js +6 -0
  508. data/vendor/assets/components/numeral/min/languages/th.min.js +6 -0
  509. data/vendor/assets/components/numeral/min/languages/tr.min.js +6 -0
  510. data/vendor/assets/components/numeral/min/languages/uk-UA.min.js +1 -0
  511. data/vendor/assets/components/numeral/min/numeral.min.js +8 -0
  512. data/vendor/assets/components/numeral/numeral.js +679 -0
  513. data/vendor/assets/components/numeral/package.json +50 -0
  514. data/vendor/assets/components/numeral/tests/languages/be-nl.js +107 -0
  515. data/vendor/assets/components/numeral/tests/languages/chs.js +101 -0
  516. data/vendor/assets/components/numeral/tests/languages/cs.js +102 -0
  517. data/vendor/assets/components/numeral/tests/languages/da-dk.js +101 -0
  518. data/vendor/assets/components/numeral/tests/languages/de-ch.js +101 -0
  519. data/vendor/assets/components/numeral/tests/languages/de.js +101 -0
  520. data/vendor/assets/components/numeral/tests/languages/en-gb.js +101 -0
  521. data/vendor/assets/components/numeral/tests/languages/en.js +98 -0
  522. data/vendor/assets/components/numeral/tests/languages/es-ES.js +101 -0
  523. data/vendor/assets/components/numeral/tests/languages/es.js +101 -0
  524. data/vendor/assets/components/numeral/tests/languages/et.js +101 -0
  525. data/vendor/assets/components/numeral/tests/languages/fi.js +101 -0
  526. data/vendor/assets/components/numeral/tests/languages/fr-CA.js +101 -0
  527. data/vendor/assets/components/numeral/tests/languages/fr-ch.js +101 -0
  528. data/vendor/assets/components/numeral/tests/languages/fr.js +101 -0
  529. data/vendor/assets/components/numeral/tests/languages/hu.js +101 -0
  530. data/vendor/assets/components/numeral/tests/languages/it.js +101 -0
  531. data/vendor/assets/components/numeral/tests/languages/ja.js +101 -0
  532. data/vendor/assets/components/numeral/tests/languages/nl-nl.js +109 -0
  533. data/vendor/assets/components/numeral/tests/languages/pl.js +102 -0
  534. data/vendor/assets/components/numeral/tests/languages/pt-br.js +101 -0
  535. data/vendor/assets/components/numeral/tests/languages/pt-pt.js +101 -0
  536. data/vendor/assets/components/numeral/tests/languages/ru-UA.js +102 -0
  537. data/vendor/assets/components/numeral/tests/languages/ru.js +102 -0
  538. data/vendor/assets/components/numeral/tests/languages/sk.js +101 -0
  539. data/vendor/assets/components/numeral/tests/languages/th.js +101 -0
  540. data/vendor/assets/components/numeral/tests/languages/tr.js +101 -0
  541. data/vendor/assets/components/numeral/tests/languages/uk-UA.js +102 -0
  542. data/vendor/assets/components/numeral/tests/numeral/format.js +204 -0
  543. data/vendor/assets/components/numeral/tests/numeral/manipulate.js +104 -0
  544. data/vendor/assets/components/numeral/tests/numeral/misc.js +123 -0
  545. data/vendor/assets/components/numeral/tests/numeral/unformat.js +96 -0
  546. data/vendor/assets/components/qunit-bdd/.bower.json +31 -0
  547. data/vendor/assets/components/qunit-bdd/LICENSE +13 -0
  548. data/vendor/assets/components/qunit-bdd/README.md +282 -0
  549. data/vendor/assets/components/qunit-bdd/bower.json +22 -0
  550. data/vendor/assets/components/qunit-bdd/karma.conf.js +70 -0
  551. data/vendor/assets/components/qunit-bdd/lib/qunit-bdd.js +755 -0
  552. data/vendor/assets/components/qunit-bdd/package.json +33 -0
  553. data/vendor/assets/javascripts/bs-breadcrumbs.js +85 -0
  554. data/vendor/assets/javascripts/bs-core.js +476 -0
  555. data/vendor/assets/javascripts/bs-notifications.js +111 -0
  556. data/vendor/assets/javascripts/daterangepicker.js +1030 -0
  557. data/vendor/assets/javascripts/fix_bind_phantomjs.js +37 -0
  558. data/vendor/assets/javascripts/jquery-deparam.js +97 -0
  559. data/vendor/assets/javascripts/sidebar-tree.js +68 -0
  560. data/vendor/assets/stylesheets/daterangepicker.css +271 -0
  561. 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);