]> git.openstreetmap.org Git - osqa.git/blobdiff - forum/authentication/__init__.py
put akismet inside of the forum dir.
[osqa.git] / forum / authentication / __init__.py
old mode 100755 (executable)
new mode 100644 (file)
index e83ba87..f6e14b7
@@ -1,27 +1,58 @@
-import re\r
-from forum.modules import get_modules_script_classes\r
-from forum.authentication.base import AuthenticationConsumer, ConsumerTemplateContext\r
-\r
-class ConsumerAndContext():\r
-    def __init__(self, id, consumer, context):\r
-        self.id = id\r
-        self.consumer = consumer()\r
-\r
-        context.id = id\r
-        self.context = context\r
-\r
-consumers = dict([\r
-            (re.sub('AuthConsumer$', '', name).lower(), cls) for name, cls\r
-            in get_modules_script_classes('authentication', AuthenticationConsumer).items()\r
-            if not re.search('AbstractAuthConsumer$', name)\r
-        ])\r
-\r
-contexts = dict([\r
-            (re.sub('AuthContext$', '', name).lower(), cls) for name, cls\r
-            in get_modules_script_classes('authentication', ConsumerTemplateContext).items()\r
-        ])\r
-\r
-AUTH_PROVIDERS = dict([\r
-            (name, ConsumerAndContext(name, consumers[name], contexts[name])) for name in consumers.keys()\r
-            if name in contexts\r
-        ])
\ No newline at end of file
+import re
+import django.dispatch
+from forum.modules import get_modules_script_classes
+from forum.authentication.base import AuthenticationConsumer, ConsumerTemplateContext
+
+class ConsumerAndContext:
+    def __init__(self, id, consumer, context):
+        self.id = id
+        self._consumer = consumer
+
+        context.id = id
+        self.context = context
+
+    @property
+    def consumer(self):
+        return self._consumer()
+
+consumers = dict([
+            (re.sub('AuthConsumer$', '', name).lower(), cls) for name, cls
+            in get_modules_script_classes('authentication', AuthenticationConsumer).items()
+            if not re.search('AbstractAuthConsumer$', name)
+        ])
+
+contexts = dict([
+            (re.sub('AuthContext$', '', name).lower(), cls) for name, cls
+            in get_modules_script_classes('authentication', ConsumerTemplateContext).items()
+        ])
+
+AUTH_PROVIDERS = dict([
+            (name, ConsumerAndContext(name, consumers[name], contexts[name])) for name in consumers.keys()
+            if name in contexts
+        ])
+
+
+#todo: probably this don't belong here, also this post_stored routine needs a lot of work
+user_logged_in = django.dispatch.Signal(providing_args=["user", "old_session"])
+user_updated = django.dispatch.Signal(providing_args=["instance", "updated_by"])
+
+#def post_stored_anonymous_content(user,old_session,**kwargs):
+#    from forum.models import AnonymousQuestion, AnonymousAnswer
+#    aq_list = AnonymousQuestion.objects.filter(session_key = old_session)
+#    aa_list = AnonymousAnswer.objects.filter(session_key = old_session)
+#    import settings
+#    if settings.EMAIL_VALIDATION == 'on':#add user to the record
+#        for aq in aq_list:
+#            aq.author = user
+#            aq.save()
+#        for aa in aa_list:
+#            aa.author = user
+#            aa.save()
+#        #maybe add pending posts message?
+#    else: #just publish the questions
+#        for aq in aq_list:
+#            aq.publish(user)
+#        for aa in aa_list:
+#            aa.publish(user)
+#
+#user_logged_in.connect(post_stored_anonymous_content)
\ No newline at end of file