Amélioré les alertes courriel, en particulier pour les évènements
authorEric Mc Sween <eric.mcsween@gmail.com>
Thu, 24 Mar 2011 16:37:36 +0000 (12:37 -0400)
committerEric Mc Sween <eric.mcsween@gmail.com>
Thu, 24 Mar 2011 16:37:36 +0000 (12:37 -0400)
Demande #1315

auf_savoirs_en_partage/savoirs/migrations/0013_auto__add_field_evenement_date_modification.py [new file with mode: 0644]
auf_savoirs_en_partage/savoirs/models.py
auf_savoirs_en_partage/savoirs/rss.py
auf_savoirs_en_partage/scripts/sphinx.conf.py.in
auf_savoirs_en_partage/templates/savoirs/rss_evenement_description.html

diff --git a/auf_savoirs_en_partage/savoirs/migrations/0013_auto__add_field_evenement_date_modification.py b/auf_savoirs_en_partage/savoirs/migrations/0013_auto__add_field_evenement_date_modification.py
new file mode 100644 (file)
index 0000000..cbaed2d
--- /dev/null
@@ -0,0 +1,309 @@
+# encoding: utf-8
+import datetime
+from south.db import db
+from south.v2 import SchemaMigration
+from django.db import models
+
+class Migration(SchemaMigration):
+
+    def forwards(self, orm):
+        
+        # Adding field 'Evenement.date_modification'
+        db.add_column('savoirs_evenement', 'date_modification', self.gf('django.db.models.fields.DateTimeField')(auto_now=True, null=True, blank=True), keep_default=False)
+
+
+    def backwards(self, orm):
+        
+        # Deleting field 'Evenement.date_modification'
+        db.delete_column('savoirs_evenement', 'date_modification')
+
+
+    models = {
+        'auth.group': {
+            'Meta': {'object_name': 'Group'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
+            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
+        },
+        'auth.permission': {
+            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
+            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
+        },
+        'auth.user': {
+            'Meta': {'object_name': 'User'},
+            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
+            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
+            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
+            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
+            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
+        },
+        'contenttypes.contenttype': {
+            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
+            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+        },
+        'datamaster_modeles.bureau': {
+            'Meta': {'object_name': 'Bureau', 'db_table': "u'ref_bureau'"},
+            'actif': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'code': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
+            'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
+            'implantation': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['datamaster_modeles.Implantation']", 'db_column': "'implantation'"}),
+            'nom': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'nom_court': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'nom_long': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'region': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['datamaster_modeles.Region']", 'db_column': "'region'"})
+        },
+        'datamaster_modeles.implantation': {
+            'Meta': {'ordering': "('nom',)", 'object_name': 'Implantation', 'db_table': "u'ref_implantation'"},
+            'actif': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'adresse_physique_bureau': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_physique_code_postal': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'adresse_physique_code_postal_avant_ville': ('django.db.models.fields.NullBooleanField', [], {'null': 'True', 'blank': 'True'}),
+            'adresse_physique_no': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'adresse_physique_pays': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'impl_adresse_physique'", 'db_column': "'adresse_physique_pays'", 'to': "orm['datamaster_modeles.Pays']"}),
+            'adresse_physique_precision': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_physique_precision_avant': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_physique_region': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_physique_rue': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_physique_ville': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'adresse_postale_boite_postale': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_postale_bureau': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_postale_code_postal': ('django.db.models.fields.CharField', [], {'max_length': '20', 'blank': 'True'}),
+            'adresse_postale_code_postal_avant_ville': ('django.db.models.fields.NullBooleanField', [], {'null': 'True', 'blank': 'True'}),
+            'adresse_postale_no': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'adresse_postale_pays': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'impl_adresse_postale'", 'db_column': "'adresse_postale_pays'", 'to': "orm['datamaster_modeles.Pays']"}),
+            'adresse_postale_precision': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_postale_precision_avant': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_postale_region': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_postale_rue': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'adresse_postale_ville': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'bureau_rattachement': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['datamaster_modeles.Implantation']", 'db_column': "'bureau_rattachement'"}),
+            'code': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
+            'code_meteo': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'commentaire': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'courriel': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
+            'courriel_interne': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
+            'date_extension': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'date_fermeture': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'date_inauguration': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'date_ouverture': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'fax': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'fax_interne': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'fuseau_horaire': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'hebergement_convention': ('django.db.models.fields.NullBooleanField', [], {'null': 'True', 'blank': 'True'}),
+            'hebergement_convention_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'hebergement_etablissement': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
+            'modif_date': ('django.db.models.fields.DateField', [], {}),
+            'nom': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'nom_court': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'nom_long': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'region': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['datamaster_modeles.Region']", 'db_column': "'region'"}),
+            'remarque': ('django.db.models.fields.TextField', [], {}),
+            'responsable_implantation': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
+            'statut': ('django.db.models.fields.IntegerField', [], {}),
+            'telephone': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'telephone_interne': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
+            'type': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'url': ('django.db.models.fields.URLField', [], {'max_length': '255', 'blank': 'True'})
+        },
+        'datamaster_modeles.pays': {
+            'Meta': {'ordering': "('nom',)", 'object_name': 'Pays', 'db_table': "u'ref_pays'"},
+            'actif': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'code': ('django.db.models.fields.CharField', [], {'max_length': '2', 'primary_key': 'True'}),
+            'code_bureau': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['datamaster_modeles.Bureau']", 'to_field': "'code'", 'db_column': "'code_bureau'"}),
+            'code_iso3': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '3', 'blank': 'True'}),
+            'developpement': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
+            'id': ('django.db.models.fields.IntegerField', [], {}),
+            'monnaie': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
+            'nom': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'nord_sud': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
+            'region': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['datamaster_modeles.Region']", 'db_column': "'region'"})
+        },
+        'datamaster_modeles.region': {
+            'Meta': {'object_name': 'Region', 'db_table': "u'ref_region'"},
+            'actif': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'code': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
+            'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
+            'implantation_bureau': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'gere_region'", 'db_column': "'implantation_bureau'", 'to': "orm['datamaster_modeles.Implantation']"}),
+            'nom': ('django.db.models.fields.CharField', [], {'max_length': '255'})
+        },
+        'datamaster_modeles.thematique': {
+            'Meta': {'object_name': 'Thematique', 'db_table': "u'ref_thematique'"},
+            'actif': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
+            'nom': ('django.db.models.fields.CharField', [], {'max_length': '255'})
+        },
+        'savoirs.actualite': {
+            'Meta': {'ordering': "['-date']", 'object_name': 'Actualite', 'db_table': "u'actualite'"},
+            'ancienid': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'db_column': "'ancienId_actualite'", 'blank': 'True'}),
+            'date': ('django.db.models.fields.DateField', [], {'db_column': "'date_actualite'"}),
+            'disciplines': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "'actualites'", 'blank': 'True', 'to': "orm['savoirs.Discipline']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True', 'db_column': "'id_actualite'"}),
+            'regions': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "'actualites'", 'blank': 'True', 'to': "orm['datamaster_modeles.Region']"}),
+            'source': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'actualites'", 'to': "orm['savoirs.SourceActualite']"}),
+            'texte': ('django.db.models.fields.TextField', [], {'db_column': "'texte_actualite'"}),
+            'titre': ('django.db.models.fields.CharField', [], {'max_length': '765', 'db_column': "'titre_actualite'"}),
+            'url': ('django.db.models.fields.CharField', [], {'max_length': '765', 'db_column': "'url_actualite'"}),
+            'visible': ('django.db.models.fields.BooleanField', [], {'default': 'False', 'db_column': "'visible_actualite'"})
+        },
+        'savoirs.actualitesearch': {
+            'Meta': {'object_name': 'ActualiteSearch'},
+            'date_max': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'date_min': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'search_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['savoirs.Search']", 'unique': 'True', 'primary_key': True})
+        },
+        'savoirs.appelsearch': {
+            'Meta': {'object_name': 'AppelSearch'},
+            'date_max': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'date_min': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'search_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['savoirs.Search']", 'unique': 'True', 'primary_key': 'True'})
+        },
+        'savoirs.discipline': {
+            'Meta': {'ordering': "['nom']", 'object_name': 'Discipline', 'db_table': "u'discipline'"},
+            'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True', 'db_column': "'id_discipline'"}),
+            'nom': ('django.db.models.fields.CharField', [], {'max_length': '765', 'db_column': "'nom_discipline'"})
+        },
+        'savoirs.evenement': {
+            'Meta': {'ordering': "['-debut']", 'object_name': 'Evenement'},
+            'adresse': ('django.db.models.fields.TextField', [], {}),
+            'approuve': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'contact': ('django.db.models.fields.TextField', [], {'null': 'True'}),
+            'courriel': ('django.db.models.fields.EmailField', [], {'max_length': '75'}),
+            'date_modification': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'debut': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'description': ('django.db.models.fields.TextField', [], {}),
+            'discipline': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'discipline'", 'null': 'True', 'to': "orm['savoirs.Discipline']"}),
+            'discipline_secondaire': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'discipline_secondaire'", 'null': 'True', 'to': "orm['savoirs.Discipline']"}),
+            'fin': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'fuseau': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'mots_cles': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'nom': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'pays': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'evenements'", 'null': 'True', 'to': "orm['datamaster_modeles.Pays']"}),
+            'piece_jointe': ('django.db.models.fields.files.FileField', [], {'max_length': '100', 'blank': 'True'}),
+            'prenom': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'regions': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'related_name': "'evenements'", 'blank': 'True', 'to': "orm['datamaster_modeles.Region']"}),
+            'titre': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'type': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'uid': ('django.db.models.fields.CharField', [], {'default': "'bac87d22-562c-11e0-93c7-f0def13a5ffb'", 'max_length': '255'}),
+            'url': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
+            'ville': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+        },
+        'savoirs.evenementsearch': {
+            'Meta': {'object_name': 'EvenementSearch', '_ormbases': ['savoirs.Search']},
+            'date_max': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'date_min': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
+            'search_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['savoirs.Search']", 'unique': 'True', 'primary_key': 'True'}),
+            'titre': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
+            'type': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'})
+        },
+        'savoirs.harvestlog': {
+            'Meta': {'object_name': 'HarvestLog'},
+            'added': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
+            'context': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'date': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'processed': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
+            'record': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['savoirs.Record']", 'null': 'True', 'blank': 'True'}),
+            'updated': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'})
+        },
+        'savoirs.listset': {
+            'Meta': {'object_name': 'ListSet'},
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'server': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'spec': ('django.db.models.fields.CharField', [], {'max_length': '255', 'primary_key': 'True'}),
+            'validated': ('django.db.models.fields.BooleanField', [], {'default': 'True'})
+        },
+        'savoirs.pagestatique': {
+            'Meta': {'object_name': 'PageStatique'},
+            'contenu': ('django.db.models.fields.TextField', [], {}),
+            'id': ('django.db.models.fields.CharField', [], {'max_length': '32', 'primary_key': 'True'}),
+            'titre': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+        },
+        'savoirs.profile': {
+            'Meta': {'object_name': 'Profile'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'serveurs': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'to': "orm['savoirs.Serveur']", 'null': 'True', 'blank': 'True'}),
+            'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['auth.User']", 'unique': 'True'})
+        },
+        'savoirs.record': {
+            'Meta': {'object_name': 'Record'},
+            'abstract': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'alt_title': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'contributor': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'creation': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
+            'creator': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'disciplines': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['savoirs.Discipline']", 'symmetrical': 'False', 'blank': 'True'}),
+            'format': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'identifier': ('django.db.models.fields.CharField', [], {'max_length': '255', 'unique': 'True', 'null': 'True', 'blank': 'True'}),
+            'isbn': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'issued': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
+            'language': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'last_checksum': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'last_update': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'listsets': ('django.db.models.fields.related.ManyToManyField', [], {'symmetrical': 'False', 'to': "orm['savoirs.ListSet']", 'null': 'True', 'blank': 'True'}),
+            'modified': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
+            'orig_lang': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'pays': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['datamaster_modeles.Pays']", 'symmetrical': 'False', 'blank': 'True'}),
+            'publisher': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'regions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['datamaster_modeles.Region']", 'symmetrical': 'False', 'blank': 'True'}),
+            'server': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'source': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'subject': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'thematiques': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['datamaster_modeles.Thematique']", 'symmetrical': 'False', 'blank': 'True'}),
+            'title': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'type': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
+            'uri': ('django.db.models.fields.CharField', [], {'max_length': '255', 'unique': 'True', 'null': 'True', 'blank': 'True'}),
+            'validated': ('django.db.models.fields.BooleanField', [], {'default': 'True'})
+        },
+        'savoirs.ressourcesearch': {
+            'Meta': {'object_name': 'RessourceSearch', '_ormbases': ['savoirs.Search']},
+            'auteur': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
+            'publisher': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
+            'search_ptr': ('django.db.models.fields.related.OneToOneField', [], {'to': "orm['savoirs.Search']", 'unique': 'True', 'primary_key': 'True'}),
+            'sujet': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
+            'titre': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'})
+        },
+        'savoirs.search': {
+            'Meta': {'object_name': 'Search'},
+            'alerte_courriel': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
+            'derniere_alerte': ('django.db.models.fields.DateField', [], {'null': 'True'}),
+            'discipline': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['savoirs.Discipline']", 'null': 'True', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'nom': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'q': ('django.db.models.fields.CharField', [], {'max_length': '100', 'blank': 'True'}),
+            'region': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['datamaster_modeles.Region']", 'null': 'True', 'blank': 'True'}),
+            'user': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['auth.User']"})
+        },
+        'savoirs.serveur': {
+            'Meta': {'object_name': 'Serveur'},
+            'nom': ('django.db.models.fields.CharField', [], {'max_length': '255', 'primary_key': 'True'})
+        },
+        'savoirs.sourceactualite': {
+            'Meta': {'object_name': 'SourceActualite'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'nom': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
+            'type': ('django.db.models.fields.CharField', [], {'default': "'actu'", 'max_length': '10'}),
+            'url': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'})
+        }
+    }
+
+    complete_apps = ['savoirs']
index 6c03e22..50dd855 100644 (file)
@@ -28,7 +28,7 @@ from markdown2 import markdown
 
 from datamaster_modeles.models import Region, Pays, Thematique
 from savoirs.globals import META
-from settings import CALENDRIER_URL, SITE_ROOT_URL
+from settings import CALENDRIER_URL, SITE_ROOT_URL, CONTACT_EMAIL
 
 # Fonctionnalités communes à tous les query sets
 
@@ -54,7 +54,7 @@ class SEPQuerySet(models.query.QuerySet, RandomQuerySetMixin):
         if min:
             qs = qs.filter(**{field + '__gte': min})
         if max:
-            qs = qs.filter(**{field + '__lte': max})
+            qs = qs.filter(**{field + '__lt': max + datetime.timedelta(days=1)})
         return qs
 
 class SEPSphinxQuerySet(SphinxQuerySet, RandomQuerySetMixin):
@@ -257,12 +257,10 @@ class EvenementQuerySet(SEPQuerySet):
         return self.filter(type=type)
 
     def filter_debut(self, min=None, max=None):
-        qs = self
-        if min:
-            qs = qs.filter(debut__gte=min)
-        if max:
-            qs = qs.filter(debut__lt=max+datetime.timedelta(days=1))
-        return qs
+        return self._filter_date('debut', min=min, max=max)
+
+    def filter_date_modification(self, min=None, max=None):
+        return self._filter_date('date_modification', min=min, max=max)
 
 class EvenementSphinxQuerySet(SEPSphinxQuerySet):
 
@@ -276,6 +274,9 @@ class EvenementSphinxQuerySet(SEPSphinxQuerySet):
     def filter_debut(self, min=None, max=None):
         return self._filter_date('debut', min=min, max=max)
 
+    def filter_date_modification(self, min=None, max=None):
+        return self._filter_date('date_modification', min=min, max=max)
+
 class EvenementManager(SEPManager):
 
     def get_query_set(self):
@@ -290,6 +291,9 @@ class EvenementManager(SEPManager):
     def filter_debut(self, min=None, max=None):
         return self.get_query_set().filter_debut(min=min, max=max)
 
+    def filter_date_modification(self, min=None, max=None):
+        return self.get_query_set().filter_date_modification(min=min, max=max)
+
 def build_time_zone_choices(pays=None):
     timezones = pytz.country_timezones[pays] if pays else pytz.common_timezones
     result = []
@@ -345,6 +349,7 @@ class Evenement(models.Model):
                                      help_text="On considère d'emblée que l'évènement se déroule dans la région "
                                                "dans laquelle se trouve le pays indiqué plus haut. Il est possible "
                                                "de désigner ici des régions additionnelles.")
+    date_modification = models.DateTimeField(editable=False, auto_now=True, null=True)
 
     objects = EvenementManager()
     all_objects = models.Manager()
@@ -386,6 +391,17 @@ class Evenement(models.Model):
     def courriel_display(self):
         return self.courriel.replace(u'@', u' (à) ')
 
+    @property
+    def lieu(self):
+        bits = []
+        if self.adresse:
+            bits.append(self.adresse)
+        if self.ville:
+            bits.append(self.ville)
+        if self.pays:
+            bits.append(self.pays.nom)
+        return ', '.join(bits)
+
     def clean(self):
         from django.core.exceptions import ValidationError
         if self.debut > self.fin:
@@ -702,6 +718,15 @@ class Search(models.Model):
         verbose_name_plural = "recherches transversales"
 
     def save(self):
+        if self.alerte_courriel:
+            try:
+                original_search = Search.objects.get(id=self.id)
+                if not original_search.alerte_courriel:
+                    # On a nouvellement activé l'alerte courriel. Notons la
+                    # date.
+                    self.derniere_alerte = datetime.date.today() - datetime.timedelta(days=1)
+            except Search.DoesNotExist:
+                self.derniere_alerte = datetime.date.today() - datetime.timedelta(days=1)
         if (not self.content_type_id):
             self.content_type = ContentType.objects.get_for_model(self.__class__)
         super(Search, self).save()
@@ -717,7 +742,6 @@ class Search(models.Model):
         from chercheurs.models import Chercheur
         from sitotheque.models import Site
 
-        results = object()
         actualites = Actualite.objects
         evenements = Evenement.objects
         ressources = Record.objects
@@ -743,13 +767,13 @@ class Search(models.Model):
             sites = sites.filter_region(self.region)
         if min_date:
             actualites = actualites.filter_date(min=min_date)
-            evenements = evenements.filter_debut(min=min_date)
+            evenements = evenements.filter_date_modification(min=min_date)
             ressources = ressources.filter_modified(min=min_date)
             chercheurs = chercheurs.filter_date_modification(min=min_date)
             sites = sites.filter_date_maj(min=min_date)
         if max_date:
             actualites = actualites.filter_date(max=max_date)
-            evenements = evenements.filter_debut(max=max_date)
+            evenements = evenements.filter_date_modification(max=max_date)
             ressources = ressources.filter_modified(max=max_date)
             chercheurs = chercheurs.filter_date_modification(max=max_date)
             sites = sites.filter_date_maj(max=max_date)
@@ -790,7 +814,7 @@ class Search(models.Model):
             results = self.as_leaf_class().run(min_date=self.derniere_alerte, max_date=yesterday)
             if results:
                 subject = 'Savoirs en partage - ' + self.nom
-                from_email = 'contact-savoirsenpartage@auf.org'
+                from_email = CONTACT_EMAIL
                 to_email = self.user.email
                 text_content = u'Voici les derniers résultats correspondant à votre recherche sauvegardée.\n\n'
                 text_content += self.as_leaf_class().get_email_alert_content(results)
@@ -804,7 +828,6 @@ rendez-vous sur le [gestionnaire de recherches sauvegardées](%s%s)''' % (SITE_R
                 msg.send()
         self.derniere_alerte = yesterday
         self.save()
-        return
 
     def get_email_alert_content(self, results):
         content = ''
@@ -853,7 +876,7 @@ rendez-vous sur le [gestionnaire de recherches sauvegardées](%s%s)''' % (SITE_R
                 content += u'-   [%s](%s%s)  \n' % (evenement.titre,
                                                     SITE_ROOT_URL,
                                                     evenement.get_absolute_url())
-                content += u'    où ? : %s, %s, %s  \n' % (evenement.adresse, evenement.ville, evenement.pays and evenement.pays.nom)
+                content += u'    où ? : %s  \n' % evenement.lieu
                 content += evenement.debut.strftime(u'    quand ? : %d/%m/%Y %H:%M  \n')
                 content += u'    durée ? : %s\n\n' % evenement.duration_display()
                 content += u'    quoi ? : '
@@ -1025,9 +1048,9 @@ class EvenementSearch(Search):
         if self.date_max:
             results = results.filter_debut(max=self.date_max)
         if min_date:
-            results = results.filter_debut(min=min_date)
+            results = results.filter_date_modification(min=min_date)
         if max_date:
-            results = results.filter_debut(max=max_date)
+            results = results.filter_date_modification(max=max_date)
         return results.all()
 
     def url(self):
@@ -1044,7 +1067,7 @@ class EvenementSearch(Search):
             content += u'-   [%s](%s%s)  \n' % (evenement.titre,
                                                 SITE_ROOT_URL,
                                                 evenement.get_absolute_url())
-            content += u'    où ? : %s, %s, %s  \n' % (evenement.adresse, evenement.ville, evenement.pays and evenement.pays.nom)
+            content += u'    où ? : %s  \n' % evenement.lieu
             content += evenement.debut.strftime(u'    quand ? : %d/%m/%Y %H:%M  \n')
             content += u'    durée ? : %s\n\n' % evenement.duration_display()
             content += u'    quoi ? : '
index 2b243c4..e9d4bf8 100644 (file)
@@ -117,9 +117,8 @@ class FilEvenements(Feed):
         return search_form.save(commit=False)
 
     def items(self, search):
-        min_date = date.today()
-        max_date = date.today() + timedelta(days=30)
-        return search.run(min_date=min_date, max_date=max_date).order_by('-debut')
+        min_date = date.today() - timedelta(days=30)
+        return search.run(min_date=min_date).order_by('-debut')
 
     def item_title(self, evenement):
         return evenement.titre
index 5f72808..be51b35 100644 (file)
@@ -146,7 +146,8 @@ emit_source('savoirsenpartage_evenements',
                       p.nom AS pays,
                       CONCAT_WS(',', d.nom_discipline, d2.nom_discipline) AS disciplines,
                       CONCAT_WS(',', pr.nom, GROUP_CONCAT(DISTINCT r.nom)) AS regions,
-                      TO_DAYS(DATE(e.debut)) AS debut
+                      TO_DAYS(DATE(e.debut)) AS debut,
+                      TO_DAYS(DATE(e.date_modification)) AS date_modification
                FROM savoirs_evenement e
                LEFT JOIN discipline d ON d.id_discipline = e.discipline_id
                LEFT JOIN discipline d2 ON d2.id_discipline = e.discipline_secondaire_id
@@ -157,7 +158,7 @@ emit_source('savoirsenpartage_evenements',
                WHERE e.approuve
                GROUP BY e.id''',
             sql_query_info='SELECT * from savoirs_evenement WHERE id=$id',
-            sql_attr_uint=['debut'])
+            sql_attr_uint=['debut', 'date_modification'])
             
 emit_source('savoirsenpartage_chercheurs',
             '''SELECT c.personne_ptr_id AS id,
index 77f7425..32974c6 100644 (file)
@@ -1,4 +1,4 @@
-<div>où ? : {{ obj.adresse }}, {{ obj.ville }}, {{ obj.pays.nom }}</div>
+<div>où ? : {{ obj.lieu }}</div>
 <div>quand ? : {{ obj.debut|date:"d F Y H:m" }}</div>
 <div>durée ? : {{ obj.duration_display }}</div>
 <p>quoi ? : {{ obj.description }}</p>