2 This XML file defines a set of producers intended for a typical indymedia
14 <nodedefinition name="Language">
16 <string name="languagecondition" defaultvalue="code != 'ot'"/>
17 <string name="bundle" defaultvalue="bundles.producer" />
22 <List key="languages" table="language" selection="${languagecondition}" order="code"/>
23 <Enumerate key="language" table="language" selection="${languagecondition}" order="code">
24 <Resource bundle="${bundle}" key="lang" language="${language.code}"/>
25 <Define key="pathprefix" value="${language.code}" />
26 <Define key="languagepreference" value="${language.code}" />
28 <If condition="language.code=='en'">
30 <Define key="pathprefix" value="or" />
31 <Define key="languagepreference" value="" />
39 <nodedefinition name="Pull">
42 <string name="blogname"/>
43 <string name="blogurl"/>
44 <string name="articletype"/>
48 <Log message="Pulling 1.0 feed from ${blogname} at ${url}" type="info" />
49 <RSS key="feeditems" url="${url}" encoding="UTF-8" />
50 <Enumerate key="item" list="feeditems['rss:item']" >
51 <Define key="languagecode" value="ot" />
52 <If condition="item['dc:language']">
54 <Set key="languagecode" value="item['dc:language']"/>
58 <If condition="item['dc:source']">
60 <Set key="origin" value="item['dc:source']"/>
63 <Set key="origin" value="item.identifier"/>
69 <If condition="item['dcterms:hasPart']">
71 <Set key="haspartimg" value="'<img align="right" src="'++item['dcterms:hasPart'] ++'" />' " />
74 <Set key="haspartimg" value="' '" />
78 <Set key="present" value="0" />
82 selection="source='${utility.escapeJDBCString(origin)}'" limit="1">
83 <Set key="present" value="1" />
85 <If condition="present==0">
87 <Log message=" new entry from ${blogname}: ${item['rss:title']}" type="info" />
92 date="utility.datetime.formatDate(item['dc:date'], 'yyyyMMdd')"
100 to_article_type="articletype"
102 content_data="item['content:encoded']++' '"
103 creator_main_url="blogurl"
104 description="haspartimg++item['rss:description']++' '"
105 to_language="languageCodeToId(languagecode)"
106 title="item['rss:title']++''"
107 webdb_create="item['dc:date']"
109 comment="'Taken from ' ++ blogname"
118 <nodedefinition name="RSSChannel">
120 <string name="articleSelection"/>
121 <string name="extratables" defaultvalue="none" />
122 <integer name="limit" defaultvalue="15"/>
123 <string name="channelidentifier" defaultvalue=""/>
124 <string name="channelfilename"/>
125 <string name="channeltitle"/>
126 <string name="articleprefix" defaultvalue="${config['Producer.PublicationHost']}/or" />
127 <string name="iconprefix" defaultvalue="${config['Producer.PublicationHost']}/icon" />
128 <string name="channelpublisher" defaultvalue="${config['Mir.Name']}" />
129 <string name="encoding" defaultvalue="UTF-8" />
130 <string name="channeldescription" defaultvalue=""/>
131 <string name="generator" defaultvalue="/RSS.template" />
135 <If condition="extratables == 'none' ">
137 <List key="articles" table="content c" selection="${articleSelection}" order = "c.webdb_create desc, c.date desc" limit="limit" />
140 <List key="articles" table="content c" selection="${articleSelection}" order = "c.webdb_create desc, c.date desc" limit="limit" extratables="${extratables}" />
143 <If condition="channeldescription==''">
145 <Define key="channeldescription" value="${channeltitle}"/>
148 <If condition="channelidentifier==''">
150 <Define key="channelidentifier" value="${config['Producer.PublicationHost']}/or/${channelfilename}"/>
155 parameters="${encoding}"
156 generator="${generator}"
157 destination="${config.storageRoot}/${channelfilename}"/>
161 <nodedefinition name="RSSChannelBundle">
163 <string name="extratables" defaultvalue="none" />
164 <string name="selection" defaultvalue="c.is_published='1'" />
165 <string name="basefilename" defaultvalue="main" />
170 articleSelection="(c.to_article_type in (${articletype.newswire}) or (c.to_article_type=${articletype.translation} and c.to_original.to_articletype in (${articletype.newswire}))) and ${selection}"
171 channelfilename="${basefilename}-newswire.rss"
172 channeltitle="${config['Mir.Name']} ${basefilename} newswire"
174 extratables="${extratables}"
177 articleSelection="(c.to_article_type in (${articletype.newswire}) or (c.to_article_type=${articletype.translation} and c.to_original.to_articletype in (${articletype.newsire}))) and ${selection}"
178 channelfilename="${basefilename}-newswire-content.rss"
179 channeltitle="${config['Mir.Name']} ${basefilename} newswire"
181 generator="RSS-full.template"
182 extratables="${extratables}"
186 articleSelection="(c.to_article_type in (${articletype.feature},${articletype.startspecial},${articletype.topicspecial}) or (c.to_article_type=${articletype.translation} and c.to_original.to_articletype in (${articletype.feature},${articletype.startspecial},${articletype.topicspecial}))) and ${selection}"
187 channelfilename="${basefilename}-features.rss"
188 channeltitle="${config['Mir.Name']} ${basefilename} features"
190 extratables="${extratables}"
193 articleSelection="(c.to_article_type in (${articletype.feature},${articletype.startspecial},${articletype.topicspecial}) or (c.to_article_type=${articletype.translation} and c.to_original.to_articletype in (${articletype.feature},${articletype.startspecial},${articletype.topicspecial}))) and ${selection}"
194 channelfilename="${basefilename}-features-content.rss"
195 channeltitle="${config['Mir.Name']} ${basefilename} features"
197 generator="RSS-full.template"
198 extratables="${extratables}"
204 <producer name="articles">
206 <verb name="changed" default="1">
207 <Define key="verbcondition" value="(not is_produced)"/>
208 <Set key="limit" value="10"/>
211 <Define key="verbcondition" value=""/>
212 <Set key="limit" value="-1"/>
216 <Define key="verbcondition" value=""/>
217 <Set key="limit" value="10"/>
221 <Enumerate key="article" table="content" selection="${verbcondition}"
222 limit="limit" order="webdb_create desc">
224 key="media" table="image"
225 selection="exists (select * from content_x_media where media_id=images.id and content_id=${article.id})
226 or exists (select * from comment_x_media, comment
227 where comment_id = comment.id and media_id=images.id and comment.to_media=${article.id})"
230 <GenerateMedia key="media" />
233 key="media" table="video"
234 selection="exists (select * from content_x_media where media_id=video.id and content_id=${article.id})
235 or exists (select * from comment_x_media, comment
236 where comment_id = comment.id and media_id=video.id and comment.to_media=${article.id})"
238 <GenerateMedia key="media" />
241 key="media" table="audio"
242 selection="exists (select * from content_x_media where media_id=audio.id and content_id=${article.id})
243 or exists (select * from comment_x_media, comment
244 where comment_id = comment.id and media_id=audio.id and comment.to_media=${article.id})"
247 <GenerateMedia key="media" />
252 key="media" table="otherMedia"
253 selection="exists (select * from content_x_media where media_id=other_media.id and content_id=${article.id})
254 or exists (select * from comment_x_media, comment
255 where comment_id = comment.id and media_id=other_media.id and comment.to_media=${article.id})"
258 <GenerateMedia key="media" />
262 <List key="topics" table="topic t" extratables="content_x_topic ctx"
263 selection="ctx.content_id = ${article.id} AND ctx.topic_id = t.id" />
264 <If condition="utility.listSize(topics) > 0">
266 <Log message="I have a topic list with ${utility.listSize(topics)}" />
269 <If condition="article.is_published == '1'">
273 generator="/article.template"
274 destination="${config.storageRoot}/${pathprefix}/${article.date.formatted.yyyy}/${article.date.formatted.MM}/${article.id}.html"/>
277 generator="/languagebar.template"
278 destination="${config.storageRoot}/languagebar/${article.to_original.date.formatted.yyyy}/${article.to_original.date.formatted.MM}/${article.to_original.id}.html"/>
279 <IndexContent key="article" pathToIndex="${config['IndexPath']}"/>
282 <UnIndexContent key="article" pathToIndex="${config['IndexPath']}"/>
285 <MarkContent key="article"/>
290 <producer name="staticpages">
292 <verb name="changed" default="1">
293 <Define key="verbcondition" value="(not is_produced)"/>
294 <Set key="limit" value="10"/>
297 <Define key="verbcondition" value=""/>
298 <Set key="limit" value="-1"/>
303 <Enumerate key="article" table="content" selection="${verbcondition} and to_article_type = ${articletype.static}"
304 limit="limit" order="webdb_create desc">
306 key="media" table="image"
307 selection="exists (select * from content_x_media where media_id=images.id and content_id=${article.id})"
310 <GenerateMedia key="media" />
313 key="media" table="video"
314 selection="exists (select * from content_x_media where media_id=video.id and content_id=${article.id})"
317 <GenerateMedia key="media" />
320 key="media" table="audio"
321 selection="exists (select * from content_x_media where media_id=audio.id and content_id=${article.id})"
324 <GenerateMedia key="media" />
327 key="media" table="otherMedia"
328 selection="exists (select * from content_x_media where media_id=other_media.id and content_id=${article.id})"
332 <GenerateMedia key="media" />
335 <If condition="article.is_published == '1'">
339 generator="/article.template"
340 destination="${config.storageRoot}/${pathprefix}/static/${article.edittitle}.html"/>
343 generator="/languagebar.template"
344 destination="${config.storageRoot}/languagebar/${article.to_original.date.formatted.yyyy}/${article.to_original.date.formatted.MM}/${article.to_original.id}.html"/>
345 <IndexContent key="article" pathToIndex="${config['IndexPath']}"/>
348 <UnIndexContent key="article" pathToIndex="${config['IndexPath']}"/>
351 <MarkContent key="article"/>
356 <producer name="navigation">
358 <verb name="generate" default="1" description="generates the left column"/>
363 generator="/navigation.template"
364 destination="${config.storageRoot}/${pathprefix}/navigation.html"/>
369 <producer name="staticimages">
371 <verb name="generate" default="1" description="copies all the static image files into place"/>
374 <CopyDir destination="img" source="etc/producer/images"/>
378 <producer name="newswirearchive">
381 <Set key="pages" value="3"/>
384 <Set key="pages" value="-1"/>
388 <Define key="docSuffix" value=".html"/>
389 <Define key="storageSuffix" value=".html"/>
391 <Batch key="articles" infokey="batch" table="content"
392 process="pages" batchsize="20" minbatchsize="10"
393 selection="is_published='1' and to_article_type = ${articletype.newswire}"
394 order="webdb_create asc">
397 <Define key="pagePrefix" value="${pathprefix}/newswire/archive"/>
398 <Define key="storagePrefix" value="${config["Producer.StorageRoot"]}/${pagePrefix}"/>
399 <Define key="docPrefix" value="${config["Producer.DocRoot"]}/${pagePrefix}"/>
402 generator="newswirearchive.template"
403 destination="${storagePrefix}${batch.current.identifier}${storageSuffix}"/>
409 <Define key="pagePrefix" value="${pathprefix}/newswire/archive"/>
410 <Define key="storagePrefix" value="${config["Producer.StorageRoot"]}/${pagePrefix}"/>
411 <Define key="docPrefix" value="${config["Producer.DocRoot"]}/${pagePrefix}"/>
413 generator="batchnav.template"
414 destination="${storagePrefix}nav${storageSuffix}"/>
421 <producer name="featurearchive">
424 <Set key="pages" value="3"/>
427 <Set key="pages" value="-1"/>
431 <Define key="docSuffix" value=".html"/>
432 <Define key="storageSuffix" value=".html"/>
434 <Batch key="articles" infokey="batch" table="content"
435 process="pages" batchsize="20" minbatchsize="10"
436 selection="is_published='1' and to_article_type in (${articletype.feature}, ${articletype.startspecial})"
437 order="webdb_create asc">
440 <Define key="pagePrefix" value="${pathprefix}/feature/archive"/>
441 <Define key="storagePrefix" value="${config["Producer.StorageRoot"]}/${pagePrefix}"/>
442 <Define key="docPrefix" value="${config["Producer.DocRoot"]}/${pagePrefix}"/>
445 generator="featurearchive.template"
446 destination="${storagePrefix}${batch.current.identifier}${storageSuffix}"/>
452 <Define key="pagePrefix" value="${pathprefix}/feature/archive"/>
453 <Define key="storagePrefix" value="${config["Producer.StorageRoot"]}/${pagePrefix}"/>
454 <Define key="docPrefix" value="${config["Producer.DocRoot"]}/${pagePrefix}"/>
456 generator="batchnav.template"
457 destination="${storagePrefix}nav${storageSuffix}"/>
464 <producer name="topicpages">
467 <Set key="_topics" value="-1"/>
468 <Set key="pages" value="3"/>
471 <Set key="_topics" value="-1"/>
472 <Set key="pages" value="-1"/>
475 <Set key="_topics" value="2"/>
476 <Set key="pages" value="4"/>
480 <Enumerate key="topic" table="topic">
481 <Define key="docSuffix" value=".html"/>
482 <Define key="storageSuffix" value=".html"/>
484 <Log message="topic = ${topic.title}" />
485 <List key="special" table="content c"
486 selection="c.is_published='1' and c.to_article_type = ${articletype.topicspecial} and c.id=cxt.content_id and cxt.topic_id = ${topic.id}"
487 order = "webdb_create desc" limit="1"
488 extratables="content_x_topic cxt"/>
490 <Batch key="articles" infokey="batch" table="content c"
491 process="pages" batchsize="20" minbatchsize="10"
492 selection="c.is_published='1' and c.to_article_type in (${articletype.newswire}, ${articletype.feature}) and c.id=cxt.content_id and cxt.topic_id = ${topic.id}"
493 order="webdb_create asc" extratables="content_x_topic cxt">
496 <Define key="pagePrefix" value="${pathprefix}/${topic.filename}/archive"/>
497 <Define key="storagePrefix" value="${config["Producer.StorageRoot"]}/${pagePrefix}"/>
498 <Define key="docPrefix" value="${config["Producer.DocRoot"]}/${pagePrefix}"/>
499 <Log message="topic now = ${topic.title}" />
502 generator="topicpage.template"
503 destination="${storagePrefix}${batch.current.identifier}${storageSuffix}"/>
509 <Define key="pagePrefix" value="${pathprefix}/${topic.filename}/archive"/>
510 <Define key="storagePrefix" value="${config["Producer.StorageRoot"]}/${pagePrefix}"/>
511 <Define key="docPrefix" value="${config["Producer.DocRoot"]}/${pagePrefix}"/>
513 generator="batchnav.template"
514 destination="${storagePrefix}nav${storageSuffix}"/>
523 <producer name="opnewswireinclude">
525 <verb name="generate" default="1" description="Generates the op newswire"/>
528 <Set key="whichnewswire" value="Open Publishing News" />
529 <List key="newswire" table="content" limit="20"
530 selection="is_published=true and to_article_type=${articletype.newswire}"
531 order="webdb_create desc"/>
534 generator="/newswireinclude.template"
535 destination="${config.storageRoot}/${pathprefix}/newswireinclude.html"/>
542 <producer name="rssnewswireinclude">
544 <verb name="generate" default="1" description="Generates the rss newswire"/>
547 <Set key="whichnewswire" value="RSS Publishing News" />
548 <List key="newswire" table="content" limit="20"
549 selection="is_published=true and to_article_type=${articletype.communityrssarticle}"
550 order="webdb_create desc"/>
553 generator="/newswireinclude.template"
554 destination="${config.storageRoot}/${pathprefix}/rssnewswireinclude.html"/>
563 <producer name="startpage">
565 <verb name="generate" default="1" description="Generates the startpage"/>
569 <List key="startspecial" table="content" limit="1"
570 selection="is_published=true and to_article_type=${articletype.startspecial}"
571 order="webdb_create desc"/>
573 <List key="features" table="content" limit="4"
574 selection="is_published=true and to_article_type in (${articletype.feature},${articletype.promotedcommunityarticle},${articletype.promotednewswire})"
575 order="webdb_create desc"/>
577 <List key="communityrssarticles" table="content" limit="10"
578 selection="is_published=true and to_article_type in (${articletype.communityrssarticle},${articletype.promotedcommunityarticle})"
579 order="webdb_create desc"/>
581 <List key="newswire" table="content" limit="20"
582 selection="is_published=true and to_article_type=${articletype.newswire}"
583 order="webdb_create desc"/>
585 <List key="mostcomments"
587 extratables="comment cm"
588 selection="c.webdb_create > NOW()-'2 years'::interval and c.is_published=true and c.id=cm.to_media group by c.id,c.title,
589 c.subtitle,c.edittitle,c.date,c.creator,c.creator_main_url,c.creator_email,c.creator_address,c.creator_phone,c.description,
590 c.comment,c.source,c.is_published,c.is_produced,c.to_publisher,c.to_language,c.to_rights,c.webdb_create,c.webdb_lastchange,
591 c.content_data,c.is_html,c.to_article_type,c.to_content,c.keywords,c.to_locking_user"
592 order="count(cm.id) desc"
597 <List key="breakingnews" table="breakingNews" limit="10"
598 order="webdb_create desc"/>
602 generator="/startpage.template"
603 destination="${config.storageRoot}/${pathprefix}/index.html"/>
608 <producer name="synchronization">
610 <verb name="run" default="1" description="Synchronizes the publication site with the production site"/>
614 <If condition="config['Rsync'] in ('1', 'y', 'yes', 'Y')">
616 <Execute command="${config['Rsync.Script.Path']}"/>
623 <producer name="media">
625 <verb name="new" default="1">
626 <Define key="verbcondition" value="(not is_produced)"/>
627 <Set key="limit" value="10"/>
630 <Define key="verbcondition" value=""/>
631 <Set key="limit" value="-1"/>
635 <Define key="verbcondition" value=""/>
636 <Set key="limit" value="10"/>
641 key="media" table="image"
642 selection="${verbcondition}"
644 order="webdb_create desc">
646 <GenerateMedia key="media" />
649 key="media" table="video"
650 selection="${verbcondition}"
652 order="webdb_create desc">
654 <GenerateMedia key="media" />
657 key="media" table="audio"
658 selection="${verbcondition}"
660 order="webdb_create desc">
662 <GenerateMedia key="media" />
665 key="media" table="otherMedia"
666 selection="${verbcondition}"
668 order="webdb_create desc">
670 <GenerateMedia key="media" />
675 <producer name="syndication">
677 <verb name="generate" />
680 <!-- the main features and newswire -->
683 <!-- the topic features and newswires -->
684 <Enumerate key="topic" table="topic">
686 basefilename="${topic.filename}"
687 selection="c.id=cxt.content_id and cxt.topic_id = ${topic.id}"
688 extratables="content_x_topic cxt"
698 <producer name="radicalendar">
703 <!-- groupname you will see as the value of "group" in the url for your radicalendar page, -->
704 <!-- gmtoffset is in minutes -->
705 <Radicalendar key="calendar" groupname="_imc" gmtoffset="60" />
707 generator="/radicalendar.template"
708 destination="${config.storageRoot}/calendarinclude.html"/>
715 <producer name="update">
717 <verb name="templates" description="updates templates and bundles">
718 <Define key="command" value="/usr/bin/rsync -rb --include=*/ --include=*.template /var/lib/mir/nyc/mir/etc/ /var/lib/mir/nyc/mir/bin/mir/WEB-INF/etc/"/>
723 <Execute command="${command}"/>
731 <producer name="generatefpincludes">
737 <Set key="counter" value="1"/>
738 <Enumerate key="fpimage" table="image" selection="to_media_folder=8 and is_published=true" >
739 <Log message="generating include for image id: ${fpimage.id}" type="info" />
742 generator="/fpinclude.template"
743 destination="${config.storageRoot}/fpincludes/${fpimage.id}.inc" />
744 <Set key="counter" value="counter+1" />
748 <List key="fpincludes" table="image" selection="to_media_folder=8 and is_published=true" />
750 generator="/fpmapping.template"
751 destination="${config.storageRoot}/fpincludes/map.txt" />
759 <!-- generates a count for each topic -->
761 <!-- TODO: add date limit when we actually are going live with this -->
762 <producer name="generateTopicCounts">
767 <FreeQuery key="topicCounts" query=" SELECT count(x.content_id) as count, t.title, t.filename FROM topic as t LEFT OUTER JOIN content_x_topic
768 as x ON (t.id=x.topic_id) LEFT OUTER JOIN content as c ON (c.id=x.content_id)
769 WHERE c.webdb_create > NOW()-'1 day'::interval AND t.archiv_url = 'Category' GROUP BY t.title , t.filename ORDER BY t.title"
772 <Generate generator="/topiccount.template"
773 destination="${config.storageRoot}/${pathprefix}/topiccount.html" />
780 <producer name="generateRandomTopics">
785 <Set key="counter" value="1"/>
787 <Enumerate key="category" table="topic t" extratables="topic t2"
788 selection="t.id=t2.id AND t.archiv_url = 'Subcategory' AND (SELECT count(*) from content_x_topic where topic_id = t.id) > 0" order="RANDOM()" limit="10">
790 <Log message="Getting Last 5 articles for category: ${category.title} - counter: ${counter}" />
791 <Define key="topictitle" value="${category.title}" />
792 <Define key="topicfile" value="${category.filename}" />
794 <List key="randomarticles" table="content"
795 selection ="id in (select content_id from content_x_topic where topic_id = ${category.id})" order="date DESC"
799 generator="/randomcategory.template"
800 destination="${config.storageRoot}/${pathprefix}/randomcats/random${counter}.html" />
803 <Set key="counter" value="counter+1" />
808 <producer name="getlocalblogs">
813 <Enumerate key="article" table="content" selection="to_article_type in(${articletype.communityrssfeed}) and is_published=true" order="webdb_create desc">
814 <Log message="Pulling 1.0 feed from ${article.title} at ${article.source}" type="info" />
816 url="${article.source}"
817 articletype="${articletype.communityrssarticle}"
818 blogurl="${article.creator_main_url}"
819 blogname="${article.title}"
825 <producer name="footer">
827 <verb name="generate" default="1" description="generates the default footer"/>
832 generator="/footer.template"
833 destination="${config.storageRoot}/${pathprefix}/footer.html"/>
839 <producer name="headArticle">
841 <verb name="generate" default="1" description="generates the article html head"/>
846 generator="/head.article.template"
847 destination="${config.storageRoot}/${pathprefix}/head.article.html"/>