muck-raker 0.1.37 → 0.1.38

Sign up to get free protection for your applications and to get access to all the features.
Files changed (303) hide show
  1. data/README.rdoc +4 -2
  2. data/VERSION +1 -1
  3. data/app/controllers/muck/aggregation_feeds_controller.rb +43 -0
  4. data/app/controllers/muck/aggregations_controller.rb +150 -260
  5. data/app/controllers/muck/topics_controller.rb +93 -0
  6. data/app/helpers/muck_raker_aggregations_helper.rb +21 -0
  7. data/app/helpers/muck_raker_feeds_helper.rb +0 -12
  8. data/app/helpers/muck_raker_google_helper.rb +70 -80
  9. data/app/models/aggregation.rb +63 -17
  10. data/app/models/aggregation_feed.rb +2 -1
  11. data/app/models/feed.rb +29 -2
  12. data/app/models/google_feed_request.rb +7 -1
  13. data/app/models/identity_feed.rb +2 -2
  14. data/app/models/service.rb +125 -31
  15. data/app/views/aggregations/_aggregation.html.erb +1 -0
  16. data/app/views/aggregations/_data_source.html.erb +2 -2
  17. data/app/views/aggregations/_feeds.html.erb +1 -0
  18. data/app/views/aggregations/_preview_form.html.erb +12 -0
  19. data/app/views/aggregations/edit.html.erb +60 -14
  20. data/app/views/aggregations/index.html.erb +17 -0
  21. data/app/views/aggregations/index.iphone.erb +0 -0
  22. data/app/views/aggregations/new.html.erb +3 -4
  23. data/app/views/aggregations/preview.html.erb +46 -0
  24. data/app/views/aggregations/preview.iphone.erb +0 -0
  25. data/app/views/aggregations/rss_discovery.html.erb +3 -0
  26. data/app/views/feeds/_form.html.erb +1 -1
  27. data/app/views/feeds/new.html.erb +1 -1
  28. data/app/views/feeds/new_extended.html.erb +1 -1
  29. data/app/views/feeds/new_oai_rss.html.erb +1 -1
  30. data/app/views/google/_feed.html.erb +33 -1
  31. data/app/views/google/_feeds_scripts.html.erb +19 -0
  32. data/app/views/raker_mailer/notification_feed_added.text.ar.html.erb +2 -1
  33. data/app/views/raker_mailer/notification_feed_added.text.ar.plain.erb +3 -1
  34. data/app/views/raker_mailer/notification_feed_added.text.bg.html.erb +3 -2
  35. data/app/views/raker_mailer/notification_feed_added.text.bg.plain.erb +4 -2
  36. data/app/views/raker_mailer/notification_feed_added.text.ca.html.erb +1 -0
  37. data/app/views/raker_mailer/notification_feed_added.text.ca.plain.erb +2 -0
  38. data/app/views/raker_mailer/notification_feed_added.text.cs.html.erb +2 -1
  39. data/app/views/raker_mailer/notification_feed_added.text.cs.plain.erb +3 -1
  40. data/app/views/raker_mailer/notification_feed_added.text.da.html.erb +2 -1
  41. data/app/views/raker_mailer/notification_feed_added.text.da.plain.erb +3 -1
  42. data/app/views/raker_mailer/notification_feed_added.text.de.html.erb +1 -0
  43. data/app/views/raker_mailer/notification_feed_added.text.de.plain.erb +2 -0
  44. data/app/views/raker_mailer/notification_feed_added.text.el.html.erb +3 -2
  45. data/app/views/raker_mailer/notification_feed_added.text.el.plain.erb +4 -2
  46. data/app/views/raker_mailer/notification_feed_added.text.es.html.erb +1 -0
  47. data/app/views/raker_mailer/notification_feed_added.text.es.plain.erb +2 -0
  48. data/app/views/raker_mailer/notification_feed_added.text.et.html.erb +2 -1
  49. data/app/views/raker_mailer/notification_feed_added.text.et.plain.erb +3 -1
  50. data/app/views/raker_mailer/notification_feed_added.text.fa.html.erb +2 -1
  51. data/app/views/raker_mailer/notification_feed_added.text.fa.plain.erb +3 -1
  52. data/app/views/raker_mailer/notification_feed_added.text.fi.html.erb +2 -1
  53. data/app/views/raker_mailer/notification_feed_added.text.fi.plain.erb +3 -1
  54. data/app/views/raker_mailer/notification_feed_added.text.fr.html.erb +2 -1
  55. data/app/views/raker_mailer/notification_feed_added.text.fr.plain.erb +3 -1
  56. data/app/views/raker_mailer/notification_feed_added.text.gl.html.erb +3 -2
  57. data/app/views/raker_mailer/notification_feed_added.text.gl.plain.erb +4 -2
  58. data/app/views/raker_mailer/notification_feed_added.text.hi.html.erb +2 -1
  59. data/app/views/raker_mailer/notification_feed_added.text.hi.plain.erb +3 -1
  60. data/app/views/raker_mailer/notification_feed_added.text.hr.html.erb +3 -2
  61. data/app/views/raker_mailer/notification_feed_added.text.hr.plain.erb +4 -2
  62. data/app/views/raker_mailer/notification_feed_added.text.hu.html.erb +3 -2
  63. data/app/views/raker_mailer/notification_feed_added.text.hu.plain.erb +4 -2
  64. data/app/views/raker_mailer/notification_feed_added.text.id.html.erb +2 -1
  65. data/app/views/raker_mailer/notification_feed_added.text.id.plain.erb +3 -1
  66. data/app/views/raker_mailer/notification_feed_added.text.it.html.erb +2 -1
  67. data/app/views/raker_mailer/notification_feed_added.text.it.plain.erb +3 -1
  68. data/app/views/raker_mailer/notification_feed_added.text.iw.html.erb +2 -1
  69. data/app/views/raker_mailer/notification_feed_added.text.iw.plain.erb +3 -1
  70. data/app/views/raker_mailer/notification_feed_added.text.ja.html.erb +4 -3
  71. data/app/views/raker_mailer/notification_feed_added.text.ja.plain.erb +5 -3
  72. data/app/views/raker_mailer/notification_feed_added.text.ko.html.erb +1 -0
  73. data/app/views/raker_mailer/notification_feed_added.text.ko.plain.erb +2 -0
  74. data/app/views/raker_mailer/notification_feed_added.text.lt.html.erb +2 -1
  75. data/app/views/raker_mailer/notification_feed_added.text.lt.plain.erb +3 -1
  76. data/app/views/raker_mailer/notification_feed_added.text.lv.html.erb +3 -2
  77. data/app/views/raker_mailer/notification_feed_added.text.lv.plain.erb +4 -2
  78. data/app/views/raker_mailer/notification_feed_added.text.mt.html.erb +2 -1
  79. data/app/views/raker_mailer/notification_feed_added.text.mt.plain.erb +3 -1
  80. data/app/views/raker_mailer/notification_feed_added.text.nl.html.erb +1 -0
  81. data/app/views/raker_mailer/notification_feed_added.text.nl.plain.erb +2 -0
  82. data/app/views/raker_mailer/notification_feed_added.text.no.html.erb +1 -0
  83. data/app/views/raker_mailer/notification_feed_added.text.no.plain.erb +2 -0
  84. data/app/views/raker_mailer/notification_feed_added.text.pl.html.erb +2 -1
  85. data/app/views/raker_mailer/notification_feed_added.text.pl.plain.erb +3 -1
  86. data/app/views/raker_mailer/notification_feed_added.text.pt-PT.html.erb +3 -2
  87. data/app/views/raker_mailer/notification_feed_added.text.pt-PT.plain.erb +4 -2
  88. data/app/views/raker_mailer/notification_feed_added.text.ro.html.erb +2 -1
  89. data/app/views/raker_mailer/notification_feed_added.text.ro.plain.erb +3 -1
  90. data/app/views/raker_mailer/notification_feed_added.text.ru.html.erb +1 -0
  91. data/app/views/raker_mailer/notification_feed_added.text.ru.plain.erb +2 -0
  92. data/app/views/raker_mailer/notification_feed_added.text.sk.html.erb +2 -1
  93. data/app/views/raker_mailer/notification_feed_added.text.sk.plain.erb +3 -1
  94. data/app/views/raker_mailer/notification_feed_added.text.sl.html.erb +2 -1
  95. data/app/views/raker_mailer/notification_feed_added.text.sl.plain.erb +3 -1
  96. data/app/views/raker_mailer/notification_feed_added.text.sq.html.erb +3 -2
  97. data/app/views/raker_mailer/notification_feed_added.text.sq.plain.erb +4 -2
  98. data/app/views/raker_mailer/notification_feed_added.text.sr.html.erb +3 -2
  99. data/app/views/raker_mailer/notification_feed_added.text.sr.plain.erb +4 -2
  100. data/app/views/raker_mailer/notification_feed_added.text.sv.html.erb +1 -0
  101. data/app/views/raker_mailer/notification_feed_added.text.sv.plain.erb +2 -0
  102. data/app/views/raker_mailer/notification_feed_added.text.th.html.erb +4 -3
  103. data/app/views/raker_mailer/notification_feed_added.text.th.plain.erb +5 -3
  104. data/app/views/raker_mailer/notification_feed_added.text.tl.html.erb +2 -1
  105. data/app/views/raker_mailer/notification_feed_added.text.tl.plain.erb +3 -1
  106. data/app/views/raker_mailer/notification_feed_added.text.tr.html.erb +3 -2
  107. data/app/views/raker_mailer/notification_feed_added.text.tr.plain.erb +4 -2
  108. data/app/views/raker_mailer/notification_feed_added.text.uk.html.erb +2 -1
  109. data/app/views/raker_mailer/notification_feed_added.text.uk.plain.erb +3 -1
  110. data/app/views/raker_mailer/notification_feed_added.text.vi.html.erb +2 -1
  111. data/app/views/raker_mailer/notification_feed_added.text.vi.plain.erb +3 -1
  112. data/app/views/raker_mailer/notification_feed_added.text.zh-CN.html.erb +4 -3
  113. data/app/views/raker_mailer/notification_feed_added.text.zh-CN.plain.erb +5 -3
  114. data/app/views/raker_mailer/notification_feed_added.text.zh-TW.html.erb +4 -3
  115. data/app/views/raker_mailer/notification_feed_added.text.zh-TW.plain.erb +5 -3
  116. data/app/views/raker_mailer/notification_feed_added.text.zh.html.erb +4 -3
  117. data/app/views/raker_mailer/notification_feed_added.text.zh.plain.erb +5 -3
  118. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ar.html.erb +4 -0
  119. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ar.plain.erb +4 -0
  120. data/app/views/raker_mailer/notification_oai_endpoint_added.text.bg.html.erb +4 -0
  121. data/app/views/raker_mailer/notification_oai_endpoint_added.text.bg.plain.erb +4 -0
  122. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ca.html.erb +4 -0
  123. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ca.plain.erb +4 -0
  124. data/app/views/raker_mailer/notification_oai_endpoint_added.text.cs.html.erb +4 -0
  125. data/app/views/raker_mailer/notification_oai_endpoint_added.text.cs.plain.erb +4 -0
  126. data/app/views/raker_mailer/notification_oai_endpoint_added.text.da.html.erb +4 -0
  127. data/app/views/raker_mailer/notification_oai_endpoint_added.text.da.plain.erb +4 -0
  128. data/app/views/raker_mailer/notification_oai_endpoint_added.text.de.html.erb +4 -0
  129. data/app/views/raker_mailer/notification_oai_endpoint_added.text.de.plain.erb +4 -0
  130. data/app/views/raker_mailer/notification_oai_endpoint_added.text.el.html.erb +4 -0
  131. data/app/views/raker_mailer/notification_oai_endpoint_added.text.el.plain.erb +4 -0
  132. data/app/views/raker_mailer/notification_oai_endpoint_added.text.es.html.erb +4 -0
  133. data/app/views/raker_mailer/notification_oai_endpoint_added.text.es.plain.erb +4 -0
  134. data/app/views/raker_mailer/notification_oai_endpoint_added.text.et.html.erb +4 -0
  135. data/app/views/raker_mailer/notification_oai_endpoint_added.text.et.plain.erb +4 -0
  136. data/app/views/raker_mailer/notification_oai_endpoint_added.text.fa.html.erb +4 -0
  137. data/app/views/raker_mailer/notification_oai_endpoint_added.text.fa.plain.erb +4 -0
  138. data/app/views/raker_mailer/notification_oai_endpoint_added.text.fi.html.erb +4 -0
  139. data/app/views/raker_mailer/notification_oai_endpoint_added.text.fi.plain.erb +4 -0
  140. data/app/views/raker_mailer/notification_oai_endpoint_added.text.fr.html.erb +4 -0
  141. data/app/views/raker_mailer/notification_oai_endpoint_added.text.fr.plain.erb +4 -0
  142. data/app/views/raker_mailer/notification_oai_endpoint_added.text.gl.html.erb +4 -0
  143. data/app/views/raker_mailer/notification_oai_endpoint_added.text.gl.plain.erb +4 -0
  144. data/app/views/raker_mailer/notification_oai_endpoint_added.text.hi.html.erb +4 -0
  145. data/app/views/raker_mailer/notification_oai_endpoint_added.text.hi.plain.erb +4 -0
  146. data/app/views/raker_mailer/notification_oai_endpoint_added.text.hr.html.erb +4 -0
  147. data/app/views/raker_mailer/notification_oai_endpoint_added.text.hr.plain.erb +4 -0
  148. data/app/views/raker_mailer/notification_oai_endpoint_added.text.hu.html.erb +4 -0
  149. data/app/views/raker_mailer/notification_oai_endpoint_added.text.hu.plain.erb +4 -0
  150. data/app/views/raker_mailer/notification_oai_endpoint_added.text.id.html.erb +4 -0
  151. data/app/views/raker_mailer/notification_oai_endpoint_added.text.id.plain.erb +4 -0
  152. data/app/views/raker_mailer/notification_oai_endpoint_added.text.it.html.erb +4 -0
  153. data/app/views/raker_mailer/notification_oai_endpoint_added.text.it.plain.erb +4 -0
  154. data/app/views/raker_mailer/notification_oai_endpoint_added.text.iw.html.erb +4 -0
  155. data/app/views/raker_mailer/notification_oai_endpoint_added.text.iw.plain.erb +4 -0
  156. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ja.html.erb +4 -0
  157. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ja.plain.erb +4 -0
  158. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ko.html.erb +4 -0
  159. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ko.plain.erb +4 -0
  160. data/app/views/raker_mailer/notification_oai_endpoint_added.text.lt.html.erb +4 -0
  161. data/app/views/raker_mailer/notification_oai_endpoint_added.text.lt.plain.erb +4 -0
  162. data/app/views/raker_mailer/notification_oai_endpoint_added.text.lv.html.erb +4 -0
  163. data/app/views/raker_mailer/notification_oai_endpoint_added.text.lv.plain.erb +4 -0
  164. data/app/views/raker_mailer/notification_oai_endpoint_added.text.mt.html.erb +4 -0
  165. data/app/views/raker_mailer/notification_oai_endpoint_added.text.mt.plain.erb +4 -0
  166. data/app/views/raker_mailer/notification_oai_endpoint_added.text.nl.html.erb +4 -0
  167. data/app/views/raker_mailer/notification_oai_endpoint_added.text.nl.plain.erb +4 -0
  168. data/app/views/raker_mailer/notification_oai_endpoint_added.text.no.html.erb +4 -0
  169. data/app/views/raker_mailer/notification_oai_endpoint_added.text.no.plain.erb +4 -0
  170. data/app/views/raker_mailer/notification_oai_endpoint_added.text.pl.html.erb +4 -0
  171. data/app/views/raker_mailer/notification_oai_endpoint_added.text.pl.plain.erb +4 -0
  172. data/app/views/raker_mailer/notification_oai_endpoint_added.text.pt-PT.html.erb +4 -0
  173. data/app/views/raker_mailer/notification_oai_endpoint_added.text.pt-PT.plain.erb +4 -0
  174. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ro.html.erb +4 -0
  175. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ro.plain.erb +4 -0
  176. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ru.html.erb +4 -0
  177. data/app/views/raker_mailer/notification_oai_endpoint_added.text.ru.plain.erb +4 -0
  178. data/app/views/raker_mailer/notification_oai_endpoint_added.text.sk.html.erb +4 -0
  179. data/app/views/raker_mailer/notification_oai_endpoint_added.text.sk.plain.erb +4 -0
  180. data/app/views/raker_mailer/notification_oai_endpoint_added.text.sl.html.erb +4 -0
  181. data/app/views/raker_mailer/notification_oai_endpoint_added.text.sl.plain.erb +4 -0
  182. data/app/views/raker_mailer/notification_oai_endpoint_added.text.sq.html.erb +4 -0
  183. data/app/views/raker_mailer/notification_oai_endpoint_added.text.sq.plain.erb +4 -0
  184. data/app/views/raker_mailer/notification_oai_endpoint_added.text.sr.html.erb +4 -0
  185. data/app/views/raker_mailer/notification_oai_endpoint_added.text.sr.plain.erb +4 -0
  186. data/app/views/raker_mailer/notification_oai_endpoint_added.text.sv.html.erb +4 -0
  187. data/app/views/raker_mailer/notification_oai_endpoint_added.text.sv.plain.erb +4 -0
  188. data/app/views/raker_mailer/notification_oai_endpoint_added.text.th.html.erb +4 -0
  189. data/app/views/raker_mailer/notification_oai_endpoint_added.text.th.plain.erb +4 -0
  190. data/app/views/raker_mailer/notification_oai_endpoint_added.text.tl.html.erb +4 -0
  191. data/app/views/raker_mailer/notification_oai_endpoint_added.text.tl.plain.erb +4 -0
  192. data/app/views/raker_mailer/notification_oai_endpoint_added.text.tr.html.erb +4 -0
  193. data/app/views/raker_mailer/notification_oai_endpoint_added.text.tr.plain.erb +4 -0
  194. data/app/views/raker_mailer/notification_oai_endpoint_added.text.uk.html.erb +4 -0
  195. data/app/views/raker_mailer/notification_oai_endpoint_added.text.uk.plain.erb +4 -0
  196. data/app/views/raker_mailer/notification_oai_endpoint_added.text.vi.html.erb +4 -0
  197. data/app/views/raker_mailer/notification_oai_endpoint_added.text.vi.plain.erb +4 -0
  198. data/app/views/raker_mailer/notification_oai_endpoint_added.text.zh-CN.html.erb +4 -0
  199. data/app/views/raker_mailer/notification_oai_endpoint_added.text.zh-CN.plain.erb +4 -0
  200. data/app/views/raker_mailer/notification_oai_endpoint_added.text.zh-TW.html.erb +4 -0
  201. data/app/views/raker_mailer/notification_oai_endpoint_added.text.zh-TW.plain.erb +4 -0
  202. data/app/views/raker_mailer/notification_oai_endpoint_added.text.zh.html.erb +4 -0
  203. data/app/views/raker_mailer/notification_oai_endpoint_added.text.zh.plain.erb +4 -0
  204. data/app/views/topics/_feed_preview.html.erb +18 -0
  205. data/app/views/topics/_form.html.erb +15 -0
  206. data/app/views/{opmls → topics}/_rss_discover.html.erb +0 -0
  207. data/app/views/{opmls → topics}/new.html.erb +7 -7
  208. data/app/views/topics/photos.html.erb +14 -0
  209. data/app/views/topics/show.html.erb +47 -0
  210. data/app/views/{opmls/index.opml.builder → topics/show.opml.builder} +0 -0
  211. data/app/views/topics/videos.html.erb +14 -0
  212. data/config/muck_raker_routes.rb +4 -3
  213. data/db/bootstrap/service_categories.yml +1 -1
  214. data/db/bootstrap/services.yml +15 -1
  215. data/db/migrate/20091006183742_add_feed_count_to_aggregation.rb +9 -0
  216. data/lib/muck_raker.rb +0 -4
  217. data/locales/ar.yml +27 -6
  218. data/locales/bg.yml +28 -7
  219. data/locales/ca.yml +30 -9
  220. data/locales/cs.yml +27 -6
  221. data/locales/da.yml +27 -6
  222. data/locales/de.yml +28 -7
  223. data/locales/el.yml +27 -6
  224. data/locales/en.yml +27 -6
  225. data/locales/es.yml +28 -7
  226. data/locales/et.yml +28 -7
  227. data/locales/fa.yml +27 -6
  228. data/locales/fi.yml +27 -6
  229. data/locales/fr.yml +27 -6
  230. data/locales/gl.yml +31 -10
  231. data/locales/hi.yml +27 -6
  232. data/locales/hr.yml +29 -8
  233. data/locales/hu.yml +29 -8
  234. data/locales/id.yml +27 -6
  235. data/locales/it.yml +29 -8
  236. data/locales/iw.yml +29 -8
  237. data/locales/ja.yml +29 -8
  238. data/locales/ko.yml +29 -8
  239. data/locales/lt.yml +30 -9
  240. data/locales/lv.yml +30 -9
  241. data/locales/mt.yml +32 -11
  242. data/locales/nl.yml +28 -7
  243. data/locales/no.yml +30 -9
  244. data/locales/pl.yml +27 -6
  245. data/locales/pt-PT.yml +27 -6
  246. data/locales/ro.yml +28 -7
  247. data/locales/ru.yml +27 -6
  248. data/locales/sk.yml +27 -6
  249. data/locales/sl.yml +30 -9
  250. data/locales/sq.yml +28 -7
  251. data/locales/sr.yml +27 -6
  252. data/locales/sv.yml +27 -6
  253. data/locales/th.yml +28 -7
  254. data/locales/tl.yml +27 -6
  255. data/locales/tr.yml +27 -6
  256. data/locales/uk.yml +27 -6
  257. data/locales/vi.yml +27 -6
  258. data/locales/zh-CN.yml +28 -7
  259. data/locales/zh-TW.yml +28 -7
  260. data/locales/zh.yml +28 -7
  261. data/muck-raker.gemspec +126 -13
  262. data/public/images/service_icons/16/metacafe.png +0 -0
  263. data/public/images/service_icons/24/metacafe.png +0 -0
  264. data/public/images/service_icons/48/metacafe.png +0 -0
  265. data/public/images/service_icons/60/metacafe.png +0 -0
  266. data/public/images/service_icons/source/bibsonomy.psd +0 -0
  267. data/public/images/service_icons/source/metacafe.psd +0 -0
  268. data/public/stylesheets/frame.css +10 -6
  269. data/public/stylesheets/muck-raker.css +77 -0
  270. data/test/rails_root/app/views/layouts/default.html.erb +1 -1
  271. data/test/rails_root/db/bootstrap/service_categories.yml +1 -1
  272. data/test/rails_root/db/bootstrap/services.yml +18 -2
  273. data/test/rails_root/db/migrate/20091006183742_add_feed_count_to_aggregation.rb +9 -0
  274. data/test/rails_root/public/images/service_icons/16/metacafe.png +0 -0
  275. data/test/rails_root/public/images/service_icons/24/metacafe.png +0 -0
  276. data/test/rails_root/public/images/service_icons/48/metacafe.png +0 -0
  277. data/test/rails_root/public/images/service_icons/60/metacafe.png +0 -0
  278. data/test/rails_root/public/images/service_icons/source/bibsonomy.psd +0 -0
  279. data/test/rails_root/public/images/service_icons/source/metacafe.psd +0 -0
  280. data/test/rails_root/public/javascripts/muck_activities.js +1 -2
  281. data/test/rails_root/public/stylesheets/application.css +0 -117
  282. data/test/rails_root/public/stylesheets/frame.css +10 -6
  283. data/test/rails_root/public/stylesheets/muck-activities.css +39 -0
  284. data/test/rails_root/public/stylesheets/muck-raker.css +77 -0
  285. data/test/rails_root/test/factories.rb +5 -0
  286. data/test/rails_root/test/functional/aggregation_feeds_controller_test.rb +67 -0
  287. data/test/rails_root/test/functional/aggregations_controller_test.rb +37 -3
  288. data/test/rails_root/test/functional/topics_controller_test.rb +46 -0
  289. data/test/rails_root/test/unit/aggregation_feed_test.rb +8 -0
  290. data/test/rails_root/test/unit/aggregation_test.rb +95 -0
  291. data/test/rails_root/test/unit/comment_test.rb +1 -1
  292. data/test/rails_root/test/unit/entry_test.rb +3 -0
  293. data/test/rails_root/test/unit/feed_test.rb +3 -0
  294. data/test/rails_root/test/unit/oai_endpoint_test.rb +3 -0
  295. data/test/rails_root/test/unit/service_test.rb +81 -11
  296. metadata +126 -13
  297. data/app/controllers/muck/opmls_controller.rb +0 -28
  298. data/app/views/google/_feed_bookmarks.html.erb +0 -13
  299. data/app/views/google/_feed_display.html.erb +0 -13
  300. data/app/views/google/_feed_photos.html.erb +0 -13
  301. data/app/views/google/_feeds_display.html.erb +0 -2
  302. data/app/views/opmls/index.html.erb +0 -19
  303. data/test/rails_root/test/functional/opmls_controller_test.rb +0 -37
@@ -1,5 +1,26 @@
1
1
  module MuckRakerGoogleHelper
2
2
 
3
+ # Render feeds using Google's api
4
+ # feeds: Feed object.
5
+ # show_controls: Indicates whether or not to show editing controls. ie Remove
6
+ # number_of_items: Number of items to display for the given feed.
7
+ # number_of_images: Number of images to get from the feed.
8
+ # number_of_videos: Number of videos to get from the feed.
9
+ # use_uri_for_control: If set to true then a hidden field will be generated containing the feed's uri. If false then the hidden field will contain the feed's service id. This is used to
10
+ # regenerate the feed after submission to the server.
11
+ # javascript_callback: Name of a javascript method to call after the feed has finished loading. The
12
+ # method should accept the feed uri and the content id. ie feed_callback(uri, content_id).
13
+ def google_feeds(feeds, show_controls = false, number_of_items = 6, number_of_images = 20, number_of_videos = 6,
14
+ use_uri_for_control = false, run_load_scripts = false, javascript_callback = 'google_load_complete')
15
+ render :partial => 'google/feed', :collection => feeds, :locals => {:number_of_items => number_of_items,
16
+ :number_of_images => number_of_images,
17
+ :number_of_videos => number_of_videos,
18
+ :javascript_callback => javascript_callback,
19
+ :show_controls => show_controls,
20
+ :use_uri_for_control => use_uri_for_control,
21
+ :run_load_scripts => run_load_scripts}
22
+ end
23
+
3
24
  # Render a google dynamic feed control.
4
25
  #
5
26
  # feeds: An array of feeds to render each with a property 'title' and 'uri' defined
@@ -36,107 +57,76 @@ module MuckRakerGoogleHelper
36
57
  options = { :displayTime => 2000, :transistionTime => 600, :scaleImages => true, :fullControlPanel => true })
37
58
  render :partial => 'google/slide_show', :locals => { :feed => feed, :content_id => content_id, :options => options }
38
59
  end
39
-
40
- # Render photos from a given feed
41
- #
42
- # feed: Url for which to generate the feed.
43
- # content_id: Name of the div that will hold the widget google generates.
44
- # If this method is called more than once on a given page then you will need to
45
- # specify different content_ids for each call.
46
- # number_of_images: Number of images to get from the feed.
47
- # javascript_callback: Name of a javascript method to call after the feed has finished loading. The
48
- # method should accept the feed uri and the content id. ie feed_callback(uri, content_id).
49
- def google_feed_photos(feed,
50
- content_id = 'feed_photo_content',
51
- number_of_images = 5,
52
- javascript_callback = nil)
53
- render :partial => 'google/feed_photos', :locals => { :feed => feed, :content_id => content_id, :number_of_images => number_of_images, :javascript_callback => javascript_callback }
54
- end
55
-
56
- # Render contents from a given feed
57
- #
58
- # feed: Url for which to generate the feed.
59
- # content_id: Name of the div that will hold the widget google generates.
60
- # If this method is called more than once on a given page then you will need to
61
- # specify different content_ids for each call.
62
- # number_of_items: Number of items to display for the given feed.
63
- # javascript_callback: Name of a javascript method to call after the feed has finished loading. The
64
- # method should accept the feed uri and the content id. ie feed_callback(uri, content_id).
65
- def google_feed_display(feed,
66
- content_id = 'feed_display_content',
67
- number_of_items = 5,
68
- javascript_callback = nil)
69
- render :partial => 'google/feed_display', :locals => { :feed => feed, :content_id => content_id, :number_of_items => number_of_items, :javascript_callback => javascript_callback }
60
+
61
+ # Given a feed attempts to assign an appropriate class
62
+ def feed_class(feed)
63
+ if feed.service.photo?
64
+ "feed-photos"
65
+ elsif feed.service.bookmark?
66
+ "feed-bookmarks"
67
+ elsif feed.service.video?
68
+ "feed-videos"
69
+ elsif feed.service.music?
70
+ "feed-music"
71
+ end
70
72
  end
71
73
 
72
- # Render bookmarks from a given feed
73
- #
74
- # feed: Url for which to generate the feed.
75
- # content_id: Name of the div that will hold the widget google generates.
76
- # If this method is called more than once on a given page then you will need to
77
- # specify different content_ids for each call.
78
- # number_of_items: Number of items to display for the given feed.
79
- # javascript_callback: Name of a javascript method to call after the feed has finished loading. The
80
- # method should accept the feed uri and the content id. ie feed_callback(uri, content_id).
81
- def google_bookmark_display(feed,
82
- content_id = 'feed_display_content',
83
- number_of_items = 5,
84
- javascript_callback = nil)
85
- render :partial => 'google/feed_bookmarks', :locals => { :feed => feed, :content_id => content_id, :number_of_items => number_of_items, :javascript_callback => javascript_callback }
74
+ # Generates a valid dom id for the feed
75
+ def feed_content_id(feed)
76
+ "feed_#{feed.id}_#{feed.title.parameterize}_#{feed.service.name.parameterize}".gsub('+', '-')
86
77
  end
87
78
 
88
- # Determines the type of feed and renders the appropriate content. For standard data feeds this will be
89
- # a list of entries. For a feed with service type photo it will render photos, etc.
90
- #
79
+ # Outputs the appropriate script for handling the google response once the feed is loaded
91
80
  # feed: Url for which to generate the feed.
92
81
  # content_id: Name of the div that will hold the widget google generates.
93
82
  # If this method is called more than once on a given page then you will need to
94
83
  # specify different content_ids for each call.
95
- # number_of_items: Number of items to display for the given feed.
96
- # number_of_images: Number of images to display if the feed is an image feed.
97
84
  # javascript_callback: Name of a javascript method to call after the feed has finished loading. The
98
85
  # method should accept the feed uri and the content id. ie feed_callback(uri, content_id).
99
- def google_muck_feed(feed, number_of_items = 5, number_of_images = 5, content_id = nil, javascript_callback = nil)
100
- content_id ||= "feed_#{feed.id}_#{feed.title.parameterize}_#{feed.service.name.parameterize}"
86
+ def google_muck_load_script(feed, content_id = nil, javascript_callback = nil)
101
87
  if feed.service.photo?
102
- google_feed_photos(feed, content_id, number_of_images, javascript_callback)
88
+ google_load_images_script(javascript_callback, feed.uri, content_id)
103
89
  elsif feed.service.bookmark?
104
- google_bookmark_display(feed, content_id, number_of_items, javascript_callback)
90
+ google_load_bookmarks_script(javascript_callback, feed.uri, content_id)
105
91
  elsif feed.service.video?
106
- # TODO for now video feeds are just data feeds.
107
- google_feed_display(feed, content_id, number_of_items, javascript_callback)
92
+ google_load_videos_script(javascript_callback, feed.uri, content_id)
93
+ elsif feed.service.music?
94
+ # TODO need to get music feeds into tag system so that we can search for music feeds and then integrate in a way that can play the tunes.
95
+ google_load_entries_script(javascript_callback, feed.uri, content_id)
108
96
  else
109
- google_feed_display(feed, content_id, number_of_items, javascript_callback)
97
+ google_load_entries_script(javascript_callback, feed.uri, content_id)
110
98
  end
111
99
  end
112
100
 
113
- # Render a collection of feeds using google.
114
- #
115
- # feeds: An array of feeds to render each with a property 'title' and 'uri' defined
116
- # content_id: Name of the div that will hold the widget google generates.
117
- # If this method is called more than once on a given page then you will need to
118
- # specify different content_ids for each call.
119
- # number_of_images: Number of images to display if the feed is an image feed.
120
- # options: A hash containing the values to pass to the Google widget. The available options are defined here:
121
- # http://www.google.com/uds/solutions/dynamicfeed/reference.html.
122
- def google_feeds_display(feeds,
123
- number_of_items = 5,
124
- number_of_images = 10,
125
- javascript_callback = nil)
126
- photo_service_ids = Service.photo_services.map(&:id)
127
- photo_feeds = feeds.find_all { |feed| photo_service_ids.include?(feed.service_id) }
128
- data_feeds = feeds - photo_feeds
129
- render :partial => 'google/feeds_display', :locals => { :data_feeds => data_feeds,
130
- :photo_feeds => photo_feeds,
131
- :photo_service_ids => photo_service_ids,
132
- :number_of_images => number_of_images,
133
- :number_of_items => number_of_items,
134
- :javascript_callback => javascript_callback }
101
+ def google_muck_load_callback_script(feed, content_id, number_of_items = 4, number_of_images = 6, number_of_videos = 6)
102
+ if feed.service.photo?
103
+ "google_load_images('#{feed.uri}', '#{content_id}', #{number_of_images});"
104
+ elsif feed.service.bookmark?
105
+ "google_load_bookmarks('#{feed.uri}', '#{content_id}', #{number_of_items});"
106
+ elsif feed.service.video?
107
+ "google_load_videos('#{feed.uri}', '#{content_id}', #{number_of_videos});"
108
+ elsif feed.service.music?
109
+ "google_load_entries('#{feed.uri}', '#{content_id}', #{number_of_items});"
110
+ else
111
+ "google_load_entries('#{feed.uri}', '#{content_id}', #{number_of_items});"
112
+ end
135
113
  end
136
114
 
115
+ def google_load_videos_script(javascript_callback, uri, content_id)
116
+ google_load_template_script 'google_load_videos', javascript_callback, uri, content_id do
117
+ %Q{var link = jQuery(item.content).find('img').parent('a');
118
+ link.attr('rel', '#{content_id}');
119
+ link.addClass('feed-video');
120
+ jQuery('#' + content_id).append(link);}
121
+ end
122
+ end
123
+
137
124
  def google_load_images_script(javascript_callback, uri, content_id)
138
125
  google_load_template_script 'google_load_images', javascript_callback, uri, content_id do
139
- %Q{jQuery('#' + content_id).append(jQuery(item.content).find('img').parent());}
126
+ %Q{var link = jQuery(item.content).find('img').parent('a');
127
+ link.attr('rel', '#{content_id}');
128
+ link.addClass('feed-photo');
129
+ jQuery('#' + content_id).append(link);}
140
130
  end
141
131
  end
142
132
 
@@ -22,23 +22,69 @@ class Aggregation < ActiveRecord::Base
22
22
  has_many :aggregation_feeds
23
23
  has_many :feeds, :through => :aggregation_feeds
24
24
 
25
+ named_scope :by_title, :order => "title ASC"
26
+ named_scope :recent, lambda { { :conditions => ['created_at > ?', 1.week.ago] } }
27
+ named_scope :newest, :order => "created_at DESC"
28
+
25
29
  # Builds and then adds feeds for a given terms
26
- def add_feeds(user, service_ids)
27
- self.feeds << Service.create_feeds(user, self.terms, service_ids)
28
- end
29
-
30
- # ##########################################################
31
- # # adds a feed to an aggregation and saves the feed
32
- # def add_feed_to_aggregation(aggregation, feed)
33
- # if aggregation.feeds.include?(feed)
34
- # self.already_feeds.push(feed)
35
- # else
36
- # if feed.save # have to save here so that feed has an id. Without id can't associate with aggregation
37
- # feed.aggregations << aggregation
38
- # self.added_feeds.push(feed )
39
- # end
40
- # end
41
- # feed.save
42
- # end
30
+ # user: User to be associated with each feed. Default is nil which makes each feed global.
31
+ # service_ids: An array of service ids. Nil will generate a feed for every available service.
32
+ def add_feeds(user = nil, service_ids = nil)
33
+ safe_add_feeds(Service.create_feeds(self.terms, user, service_ids))
34
+ end
35
+
36
+ def add_feeds_by_uri(user = nil, uris = nil)
37
+ safe_add_feeds(Feed.create_feeds(user, uris))
38
+ end
39
+
40
+ # Only add feeds that aren't already part of the aggregation
41
+ def safe_add_feeds(new_feeds)
42
+ new_feeds.each do |feed|
43
+ begin
44
+ self.feeds << feed
45
+ rescue ActiveRecord::RecordInvalid => ex
46
+ # Throw away exception. Feed already exists so we don't need to do anything.
47
+ end
48
+ end
49
+ new_feeds
50
+ end
51
+
52
+ # Get only photo feeds
53
+ def photo_feeds
54
+ all_feeds.find_all{ |feed| feed.service.photo? }
55
+ end
56
+
57
+ # Get only video feeds
58
+ def video_feeds
59
+ all_feeds.find_all{ |feed| feed.service.video? }
60
+ end
61
+
62
+ # Get only bookmark feeds
63
+ def bookmark_feeds
64
+ all_feeds.find_all{ |feed| feed.service.bookmark? }
65
+ end
66
+
67
+ # Get only music feeds
68
+ def music_feeds
69
+ all_feeds.find_all{ |feed| feed.service.music? }
70
+ end
43
71
 
72
+ # Get only general feeds (exclude all specific feeds such as photos, videos, etc)
73
+ def general_feeds
74
+ all_feeds.find_all{ |feed| feed.service.general? }
75
+ end
76
+
77
+ def all_feeds
78
+ @all_feeds ||= self.feeds.find(:all, :include => :service)
79
+ end
80
+
81
+ # Determines whether or not he given user can edit the aggregation
82
+ def can_edit?(user)
83
+ if ownable == user || user.admin?
84
+ true
85
+ else
86
+ false
87
+ end
88
+ end
89
+
44
90
  end
@@ -8,6 +8,7 @@
8
8
  #
9
9
 
10
10
  class AggregationFeed < ActiveRecord::Base
11
- belongs_to :aggregation
11
+ belongs_to :aggregation, :counter_cache => 'feed_count', :touch => true
12
12
  belongs_to :feed
13
+ validates_uniqueness_of :feed_id, :scope => :aggregation_id
13
14
  end
data/app/models/feed.rb CHANGED
@@ -144,13 +144,24 @@ class Feed < ActiveRecord::Base
144
144
  feeds = []
145
145
  @available_feeds = discover_feeds(uri)
146
146
  @available_feeds.each do |feed|
147
- feeds << from_feedzirra(Feedzirra::Feed.fetch_and_parse(feed.url)) unless feed.blank?
147
+ feeds << new_from_feedzirra(Feedzirra::Feed.fetch_and_parse(feed.url)) unless feed.blank?
148
148
  end
149
149
  feeds
150
150
  end
151
151
 
152
+ # Gathers all available feed uris from the given uri and parses them into
153
+ # feed objects
154
+ def self.feeds_from_uri(uri, user = nil)
155
+ feeds = []
156
+ @available_feeds = discover_feeds(uri)
157
+ @available_feeds.each do |feed|
158
+ feeds << create_from_feedzirra(Feedzirra::Feed.fetch_and_parse(feed.url), user) unless feed.blank?
159
+ end
160
+ feeds
161
+ end
162
+
152
163
  # Turns a feed from feedzirra into a muck feed
153
- def self.from_feedzirra(feed)
164
+ def self.new_from_feedzirra(feed)
154
165
  return if feed.blank?
155
166
  Feed.new(:short_title => feed.title,
156
167
  :title => feed.title,
@@ -158,6 +169,12 @@ class Feed < ActiveRecord::Base
158
169
  :uri => feed.feed_url)
159
170
  end
160
171
 
172
+ # Creates a feed from feedzirra into a muck feed
173
+ def self.create_from_feedzirra(feed, user)
174
+ return if feed.blank?
175
+ Feed.find_or_create(feed.feed_url, feed.title, '', '', Service.find_service_by_uri(feed.url), user, feed.url)
176
+ end
177
+
161
178
  # Looks for feeds from a given url
162
179
  def self.discover_feeds(uri)
163
180
  Feedbag.find(uri)
@@ -177,4 +194,14 @@ class Feed < ActiveRecord::Base
177
194
  :display_uri => display_uri)
178
195
  end
179
196
 
197
+ # Create feeds for the given uris
198
+ # user: User that will be set as the feed contributor
199
+ # uris: An array of uris for which to create feeds
200
+ # service: A default service to be associated with all the feeds.
201
+ def self.create_feeds(user = nil, uris = nil, service = nil)
202
+ return [] if uris.blank?
203
+ service ||= Service.default_service
204
+ uris.collect { |uri| Feed.find_or_create(uri, '', '', '', service.id, user, uri) }
205
+ end
206
+
180
207
  end
@@ -26,7 +26,13 @@ class GoogleFeedRequest
26
26
  # Search for feeds using google. This will return
27
27
  # a collection of 'Feed' objects
28
28
  def self.find_feeds(query)
29
- convert_google_json_to_feeds(find_google_feeds(query))
29
+ query = query.join('+') if query.is_a?(Array)
30
+ feed_response = find_google_feeds(query)
31
+ if 200 == feed_response['responseStatus']
32
+ convert_google_json_to_feeds(feed_response)
33
+ else
34
+ []
35
+ end
30
36
  end
31
37
 
32
38
  # Search for feeds using google. This will return
@@ -14,9 +14,9 @@ class IdentityFeed < ActiveRecord::Base
14
14
 
15
15
  validates_uniqueness_of :feed_id, :scope => [:ownable_id, :ownable_type]
16
16
 
17
- # override this method to change the way permissions are handled on comments
17
+ # Determines whether or not he given user can edit the identity feed
18
18
  def can_edit?(user)
19
- if ownable == user || check_user(user)
19
+ if ownable == user || user.admin?
20
20
  true
21
21
  else
22
22
  false
@@ -28,30 +28,43 @@ class Service < ActiveRecord::Base
28
28
 
29
29
  # Indicates whether feed is primarily a photo feed ie from flick, picasa, etc
30
30
  def photo?
31
- self.service_category.name == 'Photos'
31
+ Service.get_photo_services.include?(self)
32
32
  end
33
33
 
34
34
  # Indicates whether feed is primarily a video feed ie from youtube, etc
35
35
  def video?
36
- self.service_category.name == 'Videos'
36
+ Service.get_video_services.include?(self)
37
37
  end
38
38
 
39
39
  # Indicates whether feed is primarily a bookmark feed ie from delicious, etc
40
40
  def bookmark?
41
- self.service_category.name == 'Bookmarks'
41
+ Service.get_bookmark_services.include?(self)
42
+ end
43
+
44
+ # Indicates whether feed is primarily a music feed
45
+ def music?
46
+ Service.get_music_services.include?(self)
47
+ end
48
+
49
+ def general?
50
+ Service.get_general_services.include?(self)
42
51
  end
43
52
 
44
53
  def human_uri(tag)
45
- if self.uri_template
46
- self.uri_template.sub("{tag}", tag)
47
- else
48
- self.uri
49
- end
54
+ generate_tag_template_uri(tag, self.uri_template)
50
55
  end
51
56
 
52
57
  # Generate a uri for the current service
53
58
  def generate_tag_uri(tag)
54
- self.uri_data_template.sub("{tag}", tag)
59
+ generate_tag_template_uri(tag, self.uri_data_template)
60
+ end
61
+
62
+ def generate_tag_template_uri(tag, uri_template)
63
+ if self.name == 'Flickr'
64
+ uri_template.sub("{tag}", tag.gsub('+',',')) # flickr wants a comma deliminated list of tags
65
+ else
66
+ uri_template.sub("{tag}", tag)
67
+ end
55
68
  end
56
69
 
57
70
  def generate_uris(username = '', password = '', uri = '')
@@ -92,59 +105,140 @@ class Service < ActiveRecord::Base
92
105
  end
93
106
 
94
107
  # creates a feed for a service with a username and optional password
95
- def self.create_feeds_for_service(service, uri, username, password, contributor_id)
108
+ def self.create_feeds_for_service(service, uri, username, password, contributor)
96
109
  uris = service.generate_uris(username, password, uri)
97
- uris.collect{ |u| Feed.find_or_create(u.url, u.title, username, password, service.id, contributor_id) } if uris
110
+ uris.collect{ |u| Feed.find_or_create(u.url, u.title, username, password, service.id, contributor) } if uris
98
111
  end
99
112
 
100
- # Builds feeds (does not save them to the db) for the given term. Note that this
101
- # method calls each feed created and so it can take a while to run.
102
- def self.build_live_feeds(user_id, terms, selected_service_ids = nil)
103
- uris = generate_tag_uris(terms, selected_service_ids)
104
- feed_uris = uris.collect { |uri| Feed.discover_feeds(uri)}
105
- feed_uris.collect { |feed| Feed.new(:uri => feed.url,
106
- :title => feed.title,
107
- :service_id => service.id,
108
- :contributor_id => user_id) }
113
+ def self.build_photo_feeds(terms, user, service_ids = nil)
114
+ if service_ids.nil?
115
+ service_ids = get_photo_services.map(&:id)
116
+ else
117
+ service_ids = make_int_array(service_ids) & get_photo_services.map(&:id)
118
+ end
119
+ build_feeds(terms, user, service_ids)
120
+ end
121
+
122
+ def self.build_video_feeds(terms, user, service_ids = nil)
123
+ if service_ids.nil?
124
+ service_ids = get_video_services.map(&:id)
125
+ else
126
+ service_ids = make_int_array(service_ids) & get_video_services.map(&:id)
127
+ end
128
+ build_feeds(terms, user, service_ids)
129
+ end
130
+
131
+ def self.build_bookmark_feeds(terms, user, service_ids = nil)
132
+ if service_ids.nil?
133
+ service_ids = get_bookmark_services.map(&:id)
134
+ else
135
+ service_ids = make_int_array(service_ids) & get_bookmark_services.map(&:id)
136
+ end
137
+ build_feeds(terms, user, service_ids)
138
+ end
139
+
140
+ def self.build_music_feeds(terms, user, service_ids = nil)
141
+ if service_ids.nil?
142
+ service_ids = get_music_services.map(&:id)
143
+ else
144
+ service_ids = make_int_array(service_ids) & get_music_services.map(&:id)
145
+ end
146
+ build_feeds(terms, user, service_ids)
147
+ end
148
+
149
+ def self.build_general_feeds(terms, user, service_ids = nil)
150
+ if service_ids.nil?
151
+ service_ids = get_general_services.map(&:id)
152
+ else
153
+ service_ids = make_int_array(service_ids) & get_general_services.map(&:id)
154
+ end
155
+ build_feeds(terms, user, service_ids)
156
+ end
157
+
158
+ def self.get_photo_services
159
+ @photo_services ||= get_services.find_all{|service| service.service_category.name == 'Photos' }
160
+ end
161
+
162
+ def self.get_video_services
163
+ @video_services ||= get_services.find_all{|service| service.service_category.name == 'Videos' }
164
+ end
165
+
166
+ def self.get_bookmark_services
167
+ @bookmark_services ||= get_services.find_all{|service| service.service_category.name == 'Bookmarks' }
168
+ end
169
+
170
+ def self.get_music_services
171
+ @music_services ||= get_services.find_all{|service| service.service_category.name == 'Music' }
172
+ end
173
+
174
+ def self.get_general_services
175
+ @general_services ||= get_services.find_all{|service| !['Photos', 'Videos', 'Bookmarks', 'Music'].include?(service.service_category.name) }
109
176
  end
110
177
 
111
178
  # Builds feeds (does not save them to the db) for the given term
112
- def self.build_feeds(user_id, terms, selected_service_ids = nil)
179
+ def self.build_feeds(terms, user, selected_service_ids = nil)
113
180
  split_terms(terms).collect { |tag|
114
181
  get_services(selected_service_ids).collect { |service| Feed.new(:uri => service.generate_tag_uri(tag),
115
182
  :display_uri => service.human_uri(tag),
116
183
  :title => I18n.t('muck.raker.service_feed_name', :term => CGI.unescape(tag).humanize, :service => service.name),
117
184
  :service_id => service.id,
118
- :contributor_id => user_id) }
185
+ :contributor_id => user) }
119
186
  }.flatten!
120
187
  end
121
188
 
189
+ # Builds feeds (does not save them to the db) for the given term. Note that this
190
+ # method calls each feed created and so it can take a while to run.
191
+ def self.build_live_feeds(terms, user, selected_service_ids = nil)
192
+ uris = generate_tag_uris(terms, selected_service_ids)
193
+ feed_uris = uris.collect { |uri| Feed.discover_feeds(uri)}
194
+ feed_uris.collect { |feed| Feed.new(:uri => feed.url,
195
+ :title => feed.title,
196
+ :service_id => service.id,
197
+ :contributor_id => user) }
198
+ end
199
+
122
200
  # Create feeds for the given terms
123
- def self.create_feeds(user_id, terms, selected_service_ids = nil)
201
+ def self.create_feeds(terms, user = nil, selected_service_ids = nil)
124
202
  split_terms(terms).collect { |tag|
125
- get_services(selected_service_ids).collect { |service| Feed.find_or_create(service.generate_tag_uri(tag), tag, '', '', service.id, user_id, service.human_uri(tag)) }
203
+ get_services(selected_service_ids).collect { |service| Feed.find_or_create(service.generate_tag_uri(tag), tag, '', '', service.id, user, service.human_uri(tag)) }
126
204
  }.flatten!
127
205
  end
128
206
 
129
207
  def self.split_terms(terms)
130
- terms.split(',').collect { |tag| CGI.escape(tag.strip) }
208
+ return '' if terms.blank?
209
+ terms = terms.split(',') unless terms.is_a?(Array)
210
+ terms.collect { |tag| CGI.escape(tag.strip) }
131
211
  end
132
212
 
133
213
  def self.get_services(selected_service_ids = nil)
134
214
  if selected_service_ids
135
- selected_service_ids.collect! { |service_id| service_id.to_i }
136
- services = Service.tag_services.find_all { |service| selected_service_ids.include?(service.id) }
215
+ selected_service_ids.collect! { |service_id| service_id.to_i } # make sure the ids are ints
216
+ Service.tag_services.find_all { |service| selected_service_ids.include?(service.id) }
137
217
  else
138
- services = Service.tag_services
218
+ @services ||= Service.tag_services
139
219
  end
140
220
  end
141
221
 
142
222
  # attempts to find a service using a uri
143
- def self.find_service_by_uri(uri)
144
- @services ||= Service.all
223
+ # uri: Uri to search for. This method will attempt to all services for any part of the provided uri.
224
+ # refresh_services: Forces a refresh of the services. By default the services are cached for the duration of the request.
225
+ def self.find_service_by_uri(uri, refresh_services = false)
226
+ if refresh_services
227
+ @services = Service.all
228
+ else
229
+ @services ||= Service.all
230
+ end
145
231
  service = @services.detect { |service| service.uri && service.uri.length > 0 && (uri.include?(service.uri) || service.uri.include?(uri)) }
146
- service ||= Service.find_by_name('rss') # this will return the default rss service
232
+ service ||= default_service
147
233
  service
148
234
  end
149
235
 
236
+ def self.make_int_array(a)
237
+ a.collect{|i| i.to_i}
238
+ end
239
+
240
+ def self.default_service
241
+ Service.find_by_name('rss') # this will return the default rss service
242
+ end
243
+
150
244
  end
@@ -0,0 +1 @@
1
+ <%= aggregation.title %><%= aggregation.feed_count %>
@@ -1,4 +1,4 @@
1
1
  <li id="<%= data_source.name.parameterize %>-link" <%= service_icon_background(data_source) %> class="service-link">
2
- <%= check_box_tag "#{@parent.to_s.underscore}[service_ids][]", data_source.id, data_source_checked?(data_source) -%>
2
+ <%= check_box_tag "service_ids[]", data_source.id, data_source_checked?(data_source) -%>
3
3
  <%= data_source.name %>
4
- </li>
4
+ </li>
@@ -0,0 +1 @@
1
+ <%= google_feeds(@feeds, @show_controls, @number_of_items, @number_of_images, @number_of_videos, false, true) %>
@@ -0,0 +1,12 @@
1
+ <h2><%= I18n.t('muck.raker.new_aggregation') %></h2>
2
+ <%= text_field_tag :terms, params[:terms] %>
3
+ <p><%= t('muck.raker.terms_instructions') %></p>
4
+ <div class="button form-row">
5
+ <%= f.submit t('muck.raker.search'), :id => 'search' %>
6
+ <span id="searching_message" style="display:none;">
7
+ <%= t('muck.raker.finding_topics') %><img src="/images/spinner.gif" alt="<%= t('muck.general.loading') %>" />
8
+ </span>
9
+ </div>
10
+ <% content_for :javascript do -%>
11
+ <%= show_hide_on_click('searching_message', 'search') %>
12
+ <% end -%>