7786408d0e0c6adbf660860c904bd4a2d15bb794
[nyc.indymedia.org.git] / etc / producer / producers.xml
1 <!--
2     This XML file defines a set of producers intended for a typical indymedia site:
3     - a start page
4     - a navigational bar
5     - topic pages
6     - a newswire archive
7     - a feature archive
8     - articles
9     - media
10 -->  
11
12 <producers>
13   <nodedefinition name="Language">
14     <parameters>
15       <string name="languagecondition" defaultvalue="code != 'ot'"/>
16       <string name="bundle" defaultvalue="bundles.producer" />
17       <node name="sub"/>    
18     </parameters>
19
20     <definition>
21       <List key="languages" table="language" selection="${languagecondition}" order="code"/>
22       <Enumerate key="language" table="language" selection="${languagecondition}" order="code">
23         <Resource bundle="${bundle}" key="lang" language="${language.code}"/>
24         <Define key="pathprefix" value="${language.code}" />
25         <Define key="languagepreference" value="${language.code}" />
26         <sub/>
27         <If condition="language.code=='en'">
28           <then>
29             <Define key="pathprefix" value="or" />
30             <Define key="languagepreference" value="" />
31             <sub/>
32           </then>
33         </If>
34       </Enumerate>
35     </definition>
36   </nodedefinition>
37
38 <nodedefinition name="Pull">
39     <parameters>
40       <string name="url"/>
41       <string name="blogname"/>
42       <string name="blogurl"/>
43       <string name="articletype"/>
44     </parameters>
45
46     <definition>
47       <Log message="Pulling 1.0 feed from ${blogname} at ${url}" type="info" />
48       <RSS key="feeditems" url="${url}" encoding="UTF-8" />
49       <Enumerate key="item" list="feeditems['rss:item']" >
50         <Define key="languagecode" value="ot" />
51         <If condition="item['dc:language']">
52           <then>
53             <Set key="languagecode" value="item['dc:language']"/>
54           </then>
55         </If>
56
57         <If condition="item['dc:source']">
58           <then>
59             <Set key="origin" value="item['dc:source']"/>
60           </then>
61           <else>
62             <Set key="origin" value="item.identifier"/>
63           </else>
64         </If>
65         
66         
67
68         <If condition="item['dcterms:hasPart']">
69           <then>
70             <Set key="haspartimg" value="'&lt;img align=&quot;right&quot; src=&quot;'++item['dcterms:hasPart'] ++'&quot; /&gt;' " />
71           </then>
72           <else>
73             <Set key="haspartimg" value="' '" />
74           </else>
75         </If>
76
77         <Set key="present" value="0" />
78         <Enumerate
79           key="article"
80           table="content"
81           selection="source='${utility.escapeJDBCString(origin)}'" limit="1">
82           <Set key="present" value="1" />
83         </Enumerate>
84         <If condition="present==0">
85           <then>
86             <Log message="  new entry from ${blogname}: ${item['rss:title']}" type="info" />
87              <CreateEntity
88                key="article"
89                table="content"
90
91                date="utility.datetime.formatDate(item['dc:date'], 'yyyyMMdd')"
92                publish_path="' '"
93                to_publisher="'0'"
94                is_produced="'0'"
95                is_published="'1'"
96                is_html="'1'"
97
98                source="origin"
99                to_article_type="articletype"
100
101                content_data="item['content:encoded']++' '"
102                creator_main_url="blogurl"
103                description="haspartimg++item['rss:description']++' '"
104                to_language="languageCodeToId(languagecode)"
105                title="item['rss:title']++''"
106                webdb_create="item['dc:date']"
107                creator="blogname"
108                comment="'Taken from ' ++ blogname"
109              />
110           </then>
111         </If>
112       </Enumerate>
113     </definition>
114   </nodedefinition>
115
116
117   <nodedefinition name="RSSChannel">
118     <parameters>
119       <string name="articleSelection"/>
120       <string name="extratables" defaultvalue="none" />
121       <integer name="limit" defaultvalue="15"/>
122       <string name="channelidentifier" defaultvalue=""/>
123       <string name="channelfilename"/>
124       <string name="channeltitle"/>
125       <string name="articleprefix" defaultvalue="${config['Producer.PublicationHost']}/or" />
126       <string name="iconprefix" defaultvalue="${config['Producer.PublicationHost']}/icon" />
127       <string name="channelpublisher" defaultvalue="${config['Mir.Name']}" />
128       <string name="encoding" defaultvalue="UTF-8" />
129       <string name="channeldescription" defaultvalue=""/>
130       <string name="generator" defaultvalue="/RSS.template" />
131     </parameters>
132
133     <definition>
134       <If condition="extratables == 'none' ">
135         <then>
136           <List key="articles" table="content" selection="${articleSelection}" order = "webdb_create desc, date desc" limit="limit" />
137         </then>
138         <else>
139           <List key="articles" table="content" selection="${articleSelection}" order = "webdb_create desc, date desc" limit="limit" extratables="${extratables}" />
140         </else>
141       </If>
142       <If condition="channeldescription==''">
143         <then>
144           <Define key="channeldescription" value="${channeltitle}"/>
145         </then>
146       </If>
147       <If condition="channelidentifier==''">
148         <then>
149           <Define key="channelidentifier" value="${config['Producer.PublicationHost']}/or/${channelfilename}"/>
150         </then>
151       </If>
152
153       <Generate
154          parameters="${encoding}"
155          generator="${generator}"
156          destination="${config.storageRoot}/${channelfilename}"/>
157     </definition>
158   </nodedefinition>
159
160   <nodedefinition name="RSSChannelBundle">
161     <parameters>
162       <string name="extratables" defaultvalue="none" />
163       <string name="selection" defaultvalue="is_published='1'" />  
164       <string name="basefilename" defaultvalue="main" />
165     </parameters>
166     <definition>
167       <!-- newswire -->
168       <RSSChannel
169         articleSelection="(to_article_type in (${articletype.newswire}) or (to_article_type=${articletype.translation} and to_original.to_articletype in (${articletype.newswire}))) and ${selection}"
170         channelfilename="${basefilename}-newswire.rss"
171         channeltitle="${config['Mir.Name']} ${basefilename} newswire"
172         limit="20"
173         extratables="${extratables}"
174       />
175       <RSSChannel
176         articleSelection="(to_article_type in (${articletype.newswire}) or (to_article_type=${articletype.translation} and to_original.to_articletype in (${articletype.newsire}))) and ${selection}"
177         channelfilename="${basefilename}-newswire-content.rss"
178         channeltitle="${config['Mir.Name']} ${basefilename} newswire"
179         limit="20"
180         generator="RSS-full.template"
181         extratables="${extratables}"
182       />    
183       <!-- features -->
184       <RSSChannel
185         articleSelection="(to_article_type in (${articletype.feature},${articletype.startspecial},${articletype.topicspecial})) and ${selection}"
186         channelfilename="${basefilename}-features.rss"
187         channeltitle="${config['Mir.Name']} ${basefilename} features"
188         limit="20"
189         extratables="${extratables}"
190       />
191       <RSSChannel
192         articleSelection="(to_article_type in (${articletype.feature},${articletype.startspecial},${articletype.topicspecial})) and ${selection}"
193         channelfilename="${basefilename}-features-content.rss"
194         channeltitle="${config['Mir.Name']} ${basefilename} features"
195         limit="20"
196         generator="RSS-full.template"
197         extratables="${extratables}"
198       />
199     </definition>
200   </nodedefinition>
201
202  
203   <producer name="articles">
204     <verbs>
205       <verb name="changed" default="1">
206         <Define key="verbcondition" value="(not is_produced) and to_article_type != ${articletype.static}"/>
207         <Set key="limit" value="10"/>
208       </verb>
209       <verb name="all">
210         <Define key="verbcondition" value="to_article_type != ${articletype.static}"/>
211         <Set key="limit" value="-1"/>
212       </verb>
213
214       <verb name="sample">
215         <Define key="verbcondition" value="to_article_type != ${articletype.static}"/>
216         <Set key="limit" value="10"/>
217       </verb>
218
219       <verb name="test" >
220         <Define key="verbcondition" value="(id&gt;=5000 and id&lt;7500 ) and to_article_type != ${articletype.static}"/>
221         <Set key="limit" value="2500"/>
222       </verb>
223
224
225     </verbs>
226     <body>
227       <Enumerate key="article" table="content" selection="${verbcondition}"
228                   limit="limit" order="webdb_create desc">
229         <Enumerate 
230             key="media" table="image" 
231             selection="exists (select * from content_x_media where media_id=images.id and content_id=${article.id})
232                or      exists (select * from comment_x_media, comment
233                            where comment_id = comment.id and media_id=images.id and comment.to_media=${article.id})"
234             order="id desc">
235             
236            <GenerateMedia key="media" />
237         </Enumerate>
238         <Enumerate 
239             key="media" table="video" 
240             selection="exists (select * from content_x_media where media_id=video.id and content_id=${article.id})
241                or      exists (select * from comment_x_media, comment
242                            where comment_id = comment.id and media_id=video.id and comment.to_media=${article.id})"
243             order="id desc">
244            <GenerateMedia key="media" />
245         </Enumerate>
246         <Enumerate 
247             key="media" table="audio" 
248             selection="exists (select * from content_x_media where media_id=audio.id and content_id=${article.id})
249                or      exists (select * from comment_x_media, comment
250                                        where comment_id = comment.id and media_id=audio.id and comment.to_media=${article.id})"
251             order="id desc">
252             
253            <GenerateMedia key="media" />
254         </Enumerate>
255         
256       
257         <Enumerate 
258             key="media" table="otherMedia" 
259             selection="exists (select * from content_x_media where media_id=other_media.id and content_id=${article.id})
260                or      exists (select * from comment_x_media, comment
261                                        where comment_id = comment.id and media_id=other_media.id and comment.to_media=${article.id})"
262             order="id desc">
263             
264            <GenerateMedia key="media" />
265         </Enumerate>
266
267
268               <List key="topics" table="topic t" extratables="content_x_topic ctx"
269                 selection="ctx.content_id = ${article.id} AND ctx.topic_id = t.id"  />
270                    <If condition="utility.listSize(topics) > 0">
271                    <then>
272                         <Log message="I have a topic list with ${utility.listSize(topics)}" />
273                     </then>
274                    </If>
275         <If condition="article.is_published == '1'">
276           <then>
277             <Language>
278               <Generate 
279                 generator="/article.template" 
280                 destination="${config.storageRoot}/${pathprefix}/${article.date.formatted.yyyy}/${article.date.formatted.MM}/${article.id}.html"/>
281              </Language>
282              <Generate 
283                 generator="/languagebar.template" 
284                 destination="${config.storageRoot}/languagebar/${article.to_original.date.formatted.yyyy}/${article.to_original.date.formatted.MM}/${article.to_original.id}.html"/>    
285              <IndexContent key="article" pathToIndex="${config['IndexPath']}"/>
286           </then>
287           <else>
288             <UnIndexContent key="article" pathToIndex="${config['IndexPath']}"/>
289           </else>
290         </If>
291         <MarkContent key="article"/>            
292       </Enumerate>
293     </body>
294   </producer>  
295
296   <producer name="staticpages">
297     <verbs>
298       <verb name="changed" default="1">
299         <Define key="verbcondition" value="(not is_produced) and to_article_type = ${articletype.static}"/>
300         <Set key="limit" value="10"/>
301       </verb>
302       <verb name="all">
303         <Define key="verbcondition" value="to_article_type = ${articletype.static}"/>
304         <Set key="limit" value="-1"/>
305       </verb>
306     </verbs>
307
308     <body>
309       <Enumerate key="article" table="content" selection="${verbcondition}"
310                   limit="limit" order="webdb_create desc">
311         <Enumerate 
312             key="media" table="image" 
313             selection="exists (select * from content_x_media where media_id=images.id and content_id=${article.id})"
314             order="id desc">
315             
316            <GenerateMedia key="media" />
317         </Enumerate>
318         <Enumerate 
319             key="media" table="video" 
320             selection="exists (select * from content_x_media where media_id=video.id and content_id=${article.id})"
321             order="id desc">
322
323            <GenerateMedia key="media" />
324         </Enumerate>
325         <Enumerate 
326             key="media" table="audio" 
327             selection="exists (select * from content_x_media where media_id=audio.id and content_id=${article.id})"
328             order="id desc">
329             
330            <GenerateMedia key="media" />
331         </Enumerate>
332         <Enumerate 
333             key="media" table="otherMedia" 
334             selection="exists (select * from content_x_media where media_id=other_media.id and content_id=${article.id})"
335
336             order="id desc">
337             
338            <GenerateMedia key="media" />
339         </Enumerate>
340        <List key="topics" table="topic t" extratables="content_x_topic ctx"
341                 selection="ctx.content_id = ${article.id} AND ctx.topic_id = t.id"  />
342
343         <If condition="article.is_published == '1'">
344           <then>
345             <Language>
346               <Generate 
347                 generator="/staticpage.template" 
348                 destination="${config.storageRoot}/${pathprefix}/static/${article.edittitle}.html"/>
349              </Language>
350
351              <Generate 
352                 generator="/languagebar.template" 
353                 destination="${config.storageRoot}/languagebar/${article.to_original.date.formatted.yyyy}/${article.to_original.date.formatted.MM}/${article.to_original.id}.html"/>    
354              <IndexContent key="article" pathToIndex="${config['IndexPath']}"/>
355           </then>
356           <else>
357             <UnIndexContent key="article" pathToIndex="${config['IndexPath']}"/>
358           </else>
359         </If>
360         <MarkContent key="article"/>            
361       </Enumerate>
362     </body>
363   </producer>
364
365   <producer name="navigation">
366     <verbs>
367       <verb name="generate" default="1" description="generates the left column"/>
368     </verbs>
369     <body>
370       <Language>
371         <Generate 
372             generator="/navigation.template" 
373             destination="${config.storageRoot}/${pathprefix}/navigation.html"/>
374       </Language>
375     </body>
376   </producer>
377   
378   <producer name="staticimages">
379     <verbs>
380       <verb name="generate" default="1" description="copies all the static image files into place"/>
381     </verbs>
382     <body>
383       <CopyDir destination="img" source="etc/producer/images"/>
384     </body>
385   </producer>
386   
387   
388    <producer name="staticfiles">
389     <verbs>
390       <verb name="generate" default="1" description="copies all the static image files into place"/>
391     </verbs>
392     <body>
393       <CopyDir destination="js" source="etc/producer/js"/>
394     </body>
395   </producer>
396   
397   <producer name="newswirearchive">
398     <verbs>
399       <verb name="new">
400         <Set key="pages" value="3"/>
401       </verb>
402       <verb name="all">
403         <Set key="pages" value="-1"/>
404       </verb>
405     </verbs>
406     <body>
407         <Define key="docSuffix" value=".html"/>
408         <Define key="storageSuffix" value=".html"/>
409
410         <Batch key="articles" infokey="batch" table="content"
411                process="pages" batchsize="20" minbatchsize="10"
412                selection="is_published='1' and to_article_type = ${articletype.newswire}"
413                order="webdb_create asc">
414           <batches>
415             <Language>
416               <Define key="pagePrefix" value="${pathprefix}/newswire/archive"/>
417               <Define key="storagePrefix" value="${config[&quot;Producer.StorageRoot&quot;]}/${pagePrefix}"/>
418               <Define key="docPrefix" value="${config[&quot;Producer.DocRoot&quot;]}/${pagePrefix}"/>
419
420               <Generate
421                   generator="newswirearchive.template"
422                   destination="${storagePrefix}${batch.current.identifier}${storageSuffix}"/>
423
424             </Language>
425           </batches>
426           <batchlist>
427             <Language>
428               <Define key="pagePrefix" value="${pathprefix}/newswire/archive"/>
429               <Define key="storagePrefix" value="${config[&quot;Producer.StorageRoot&quot;]}/${pagePrefix}"/>
430               <Define key="docPrefix" value="${config[&quot;Producer.DocRoot&quot;]}/${pagePrefix}"/>
431               <Generate
432                   generator="batchnav.template"
433                   destination="${storagePrefix}nav${storageSuffix}"/>
434             </Language>
435           </batchlist>
436         </Batch>
437     </body>
438   </producer>
439
440   <producer name="featurearchive">
441     <verbs>
442       <verb name="new">
443         <Set key="pages" value="3"/>
444       </verb>
445       <verb name="all">
446         <Set key="pages" value="-1"/>
447       </verb> 
448     </verbs>
449     <body>
450         <Define key="docSuffix" value=".html"/>
451         <Define key="storageSuffix" value=".html"/>
452         
453         <Batch key="articles" infokey="batch" table="content" 
454                process="pages" batchsize="20" minbatchsize="10"
455                selection="is_published='1' and to_article_type in (${articletype.feature}, ${articletype.startspecial})"
456                order="webdb_create asc">
457           <batches>
458             <Language>
459               <Define key="pagePrefix" value="${pathprefix}/feature/archive"/>
460               <Define key="storagePrefix" value="${config[&quot;Producer.StorageRoot&quot;]}/${pagePrefix}"/>
461               <Define key="docPrefix" value="${config[&quot;Producer.DocRoot&quot;]}/${pagePrefix}"/>
462
463               <Generate 
464                   generator="featurearchive.template" 
465                   destination="${storagePrefix}${batch.current.identifier}${storageSuffix}"/>
466
467             </Language>
468           </batches>
469           <batchlist>
470             <Language>
471               <Define key="pagePrefix" value="${pathprefix}/feature/archive"/>
472               <Define key="storagePrefix" value="${config[&quot;Producer.StorageRoot&quot;]}/${pagePrefix}"/>
473               <Define key="docPrefix" value="${config[&quot;Producer.DocRoot&quot;]}/${pagePrefix}"/>
474               <Generate 
475                   generator="batchnav.template" 
476                   destination="${storagePrefix}nav${storageSuffix}"/>
477             </Language>
478           </batchlist>
479         </Batch>
480     </body>
481   </producer>
482
483   <producer name="topicpages">
484     <verbs>
485       <verb name="new">
486         <Set key="_topics" value="-1"/>
487         <Set key="pages" value="3"/>
488       </verb>
489       <verb name="all">
490         <Set key="_topics" value="-1"/>
491         <Set key="pages" value="-1"/>
492       </verb> 
493       <verb name="sample">
494         <Set key="_topics" value="2"/>
495         <Set key="pages" value="4"/>
496       </verb> 
497     </verbs>
498     <body>
499       <Enumerate key="topic" table="topic">
500         <Define key="docSuffix" value=".html"/>
501         <Define key="storageSuffix" value=".html"/>
502         
503         <Log message="topic = ${topic.title}" />
504         <List key="special" table="content c" 
505           selection="c.is_published='1' and c.to_article_type = ${articletype.topicspecial} and c.id=cxt.content_id and cxt.topic_id = ${topic.id}"
506           order = "webdb_create desc" limit="1"
507           extratables="content_x_topic cxt"/>
508       
509         <Batch key="articles" infokey="batch" table="content c" 
510                process="pages" batchsize="20" minbatchsize="10"
511                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}"
512                order="webdb_create asc" extratables="content_x_topic cxt">
513           <batches>
514             <Language>
515               <Define key="pagePrefix" value="${pathprefix}/${topic.filename}/archive"/>
516               <Define key="storagePrefix" value="${config[&quot;Producer.StorageRoot&quot;]}/${pagePrefix}"/>
517               <Define key="docPrefix" value="${config[&quot;Producer.DocRoot&quot;]}/${pagePrefix}"/>
518                   <Log message="topic now = ${topic.title}" />
519
520               <Generate 
521                   generator="topicpage.template" 
522                   destination="${storagePrefix}${batch.current.identifier}${storageSuffix}"/>
523
524             </Language>
525           </batches>
526           <batchlist>
527             <Language>
528               <Define key="pagePrefix" value="${pathprefix}/${topic.filename}/archive"/>
529               <Define key="storagePrefix" value="${config[&quot;Producer.StorageRoot&quot;]}/${pagePrefix}"/>
530               <Define key="docPrefix" value="${config[&quot;Producer.DocRoot&quot;]}/${pagePrefix}"/>
531               <Generate 
532                   generator="batchnav.template" 
533                   destination="${storagePrefix}nav${storageSuffix}"/>
534             </Language>
535           </batchlist>
536         </Batch>
537       </Enumerate>
538     </body>
539   </producer>
540
541
542   <producer name="opnewswireinclude">
543     <verbs>
544       <verb name="generate" default="1" description="Generates the op newswire"/>
545     </verbs>
546 <body>
547 <Set key="whichnewswire" value="Open Publishing News" />
548       <List key="newswire" table="content" limit="50"
549         selection="is_published=true and to_article_type=${articletype.newswire}"
550         order="webdb_create desc"/>
551       <Language>
552         <Generate 
553             generator="/newswireinclude.template" 
554             destination="${config.storageRoot}/${pathprefix}/newswireinclude.html"/>
555       </Language>
556
557
558 </body>
559 </producer>
560
561   <producer name="rssnewswireinclude">
562     <verbs>
563       <verb name="generate" default="1" description="Generates the rss newswire"/>
564     </verbs>
565 <body>
566 <Set key="whichnewswire" value="RSS Publishing News" />
567       <List key="newswire" table="content" limit="20"
568         selection="is_published=true and to_article_type=${articletype.communityrssarticle}"
569         order="webdb_create desc"/>
570       <Language>
571         <Generate 
572             generator="/newswireinclude.template" 
573             destination="${config.storageRoot}/${pathprefix}/rssnewswireinclude.html"/>
574       </Language>
575
576
577 </body>
578 </producer>
579
580
581   
582   <producer name="startpage">
583     <verbs>
584       <verb name="generate" default="1" description="Generates the startpage"/>
585     </verbs>
586
587     <body>
588       <List key="startspecial" table="content" limit="1"
589         selection="is_published=true and to_article_type=${articletype.startspecial}"
590         order="webdb_create desc"/>
591                                         
592       <List key="features" table="content" limit="5" 
593         selection="is_published=true and to_article_type in (${articletype.feature},${articletype.promotedcommunityarticle},${articletype.promotednewswire})"
594         order="webdb_create desc"/>
595
596       <List key="communityrssarticles" table="content" limit="10" 
597         selection="is_published=true and to_article_type in (${articletype.communityrssarticle},${articletype.promotedcommunityarticle})"
598         order="webdb_create desc"/>
599
600       <List key="newswire" table="content" limit="20"
601         selection="is_published=true and to_article_type=${articletype.newswire}"
602         order="webdb_create desc"/>
603         
604       <List key="mostcomments"
605                   table="content c"
606                   extratables="comment cm"
607                   selection="c.webdb_create > NOW()-'1 week'::interval and c.is_published=true and cm.is_published=true and c.id=cm.to_media group by c.id,c.title,
608                                          c.subtitle,c.edittitle,c.date,c.creator,c.creator_main_url,c.creator_email,c.creator_address,c.creator_phone,c.description,
609                                          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,
610                                          c.content_data,c.is_html,c.to_article_type,c.to_content,c.keywords,c.to_locking_user"
611                           order="count(cm.id) desc, c.webdb_create desc "
612                           limit="3"
613                     />    
614                 
615         
616       <List key="breakingnews" table="breakingNews" limit="10"
617          order="webdb_create desc"/>
618         
619       <Language>
620         <Generate 
621             generator="/startpage.template" 
622             destination="${config.storageRoot}/${pathprefix}/index.html"/>
623       </Language>
624     </body>
625   </producer>  
626   
627   <producer name="synchronization">
628     <verbs>
629       <verb name="run" default="1" description="Synchronizes the publication site with the production site"/>
630     </verbs>
631
632     <body>
633       <If condition="config['Rsync'] in ('1', 'y', 'yes', 'Y')">
634         <then>
635           <Execute command="${config['Rsync.Script.Path']}"/>
636         </then>
637       </If>
638     </body>
639   </producer>  
640   
641   
642   <producer name="media">
643     <verbs>
644       <verb name="new" default="1">
645         <Define key="verbcondition" value="(not is_produced)"/>
646         <Set key="limit" value="10"/>
647       </verb>
648       <verb name="all">
649         <Define key="verbcondition" value=""/>
650         <Set key="limit" value="-1"/>
651       </verb>
652
653       <verb name="sample">
654         <Define key="verbcondition" value=""/>
655         <Set key="limit" value="10"/>
656       </verb>
657     </verbs>
658     <body>
659       <Enumerate 
660           key="media" table="image" 
661           selection="${verbcondition}"
662           limit="limit" 
663           order="webdb_create desc">
664           
665          <GenerateMedia key="media" />
666       </Enumerate>
667       <Enumerate 
668           key="media" table="video" 
669           selection="${verbcondition}"
670           limit="limit" 
671           order="webdb_create desc">
672           
673          <GenerateMedia key="media" />
674       </Enumerate>
675       <Enumerate 
676           key="media" table="audio" 
677           selection="${verbcondition}"
678           limit="limit" 
679           order="webdb_create desc">
680           
681          <GenerateMedia key="media" />
682       </Enumerate>
683       <Enumerate 
684           key="media" table="otherMedia" 
685           selection="${verbcondition}"
686           limit="limit" 
687           order="webdb_create desc">
688           
689          <GenerateMedia key="media" />
690       </Enumerate>
691     </body>
692   </producer>  
693
694   <producer name="syndication">
695     <verbs>
696       <verb name="generate" />
697     </verbs>
698     <body>
699       <!-- the main features and newswire -->
700       <RSSChannelBundle />
701       
702       <!-- the topic features and newswires -->
703       <Enumerate key="topic" table="topic">
704         <RSSChannelBundle
705           basefilename="${topic.filename}"
706           selection="id=cxt.content_id and cxt.topic_id = ${topic.id}"
707           extratables="content_x_topic as cxt"
708         />
709       </Enumerate>
710       
711       
712
713     </body>
714
715   </producer>
716
717   <producer name="radicalendar">
718     <verbs>
719       <verb name="pull" />
720     </verbs>
721     <body>
722       <!-- groupname you will see as the value of "group" in the url for your radicalendar page, -->
723       <!--      gmtoffset is in minutes                                                          -->
724       <Radicalendar key="calendar" groupname="_imc" gmtoffset="60"  />
725       <Generate 
726         generator="/radicalendar.template" 
727         destination="${config.storageRoot}/calendarinclude.html"/>
728
729
730     </body>
731   </producer>
732
733
734   <producer name="update">
735     <verbs>
736       <verb name="templates" description="updates templates and bundles">
737         <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/"/>
738       </verb>
739     </verbs>
740
741     <body>
742       <Execute command="${command}"/>
743     </body>
744   </producer>
745
746
747
748
749
750  <producer name="generatefpincludes">
751    <verbs>
752      <verb name="doit" />
753    </verbs>
754    <body>
755
756         <Set key="counter" value="1"/>
757       <Enumerate key="fpimage" table="image" selection="to_media_folder=8 and is_published=true" >
758         <Log message="generating include for image id: ${fpimage.id}" type="info" />
759
760           <Generate
761                 generator="/fpinclude.template"
762                 destination="${config.storageRoot}/fpincludes/${fpimage.id}.inc" />
763        <Set key="counter" value="counter+1" />
764       </Enumerate>
765
766
767            <List key="fpincludes" table="image" selection="to_media_folder=8 and is_published=true" />
768                 <Generate
769                         generator="/fpmapping.template"
770                         destination="${config.storageRoot}/fpincludes/map.txt" />
771
772     </body>
773   </producer>
774
775
776
777
778  <!-- generates a count for each topic -->
779  
780  <!-- TODO: add date limit when we actually are going live with this -->        
781  <producer name="generateTopicCounts"> 
782  <verbs>
783         <verb name="doit" />
784  </verbs>
785  <body>
786         <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 
787                                                                                  as x ON (t.id=x.topic_id) LEFT OUTER JOIN content as c ON (c.id=x.content_id) 
788                                                                                  WHERE c.webdb_create > NOW()-'1 day'::interval AND  t.archiv_url = 'Category' GROUP BY t.title , t.filename ORDER BY t.title"
789                    type="set"/>
790         <Language>          
791         <Generate generator="/topiccount.template"
792                 destination="${config.storageRoot}/${pathprefix}/topiccount.html" />
793         </Language>
794   </body>
795   </producer>
796                 
797
798
799  <producer name="generateRandomTopics">
800   <verbs>
801     <verb name="doit" />
802   </verbs>
803   <body>
804         <Set key="counter" value="1"/>
805         
806         <Enumerate key="category" table="topic t" extratables="topic t2"
807                 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">
808         
809         <Log message="Getting Last 5 articles for category: ${category.title} - counter: ${counter}" />
810         <Define key="topictitle" value="${category.title}" />
811         <Define key="topicfile" value="${category.filename}" /> 
812         
813         <List key="randomarticles" table="content"
814                 selection ="id in (select content_id from content_x_topic where topic_id = ${category.id}) AND is_published=true" order="date DESC"
815                 limit="3" />
816         <Language>      
817         <Generate
818                 generator="/randomcategory.template"
819                 destination="${config.storageRoot}/${pathprefix}/randomcats/random${counter}.html" />        
820         </Language>
821         
822         <Set key="counter" value="counter+1" />
823     </Enumerate>
824   </body>
825  </producer>
826                           
827  <producer name="getlocalblogs">
828    <verbs>
829      <verb name="doit" />
830    </verbs>
831    <body>
832       <Enumerate key="article" table="content" selection="to_article_type in(${articletype.communityrssfeed}) and is_published=true"  order="webdb_create desc">
833         <Log message="Pulling 1.0 feed from ${article.title} at ${article.source}" type="info" />
834         <Pull
835           url="${article.source}"
836           articletype="${articletype.communityrssarticle}"
837           blogurl="${article.creator_main_url}"
838           blogname="${article.title}"
839         />
840       </Enumerate>
841     </body>
842   </producer>
843
844   <producer name="footer">
845     <verbs>
846       <verb name="generate" default="1" description="generates the default footer"/>
847     </verbs>
848     <body>
849       <Language>
850         <Generate
851             generator="/footer.template"
852             destination="${config.storageRoot}/${pathprefix}/footer.html"/>
853       </Language>
854     </body>
855   </producer>
856
857
858   <producer name="headArticle">
859     <verbs>
860       <verb name="generate" default="1" description="generates the article html head"/>
861     </verbs>
862     <body>
863       <Language>
864         <Generate
865             generator="/head.article.template"
866             destination="${config.storageRoot}/${pathprefix}/head.article.html"/>
867       </Language>
868     </body>
869   </producer>
870   
871 </producers>
872
873