Merge branch 'master' into cgi
authorJames French <[email protected]>
Mon, 4 Mar 2013 08:46:27 +0000 (16:46 +0800)
committerJames French <[email protected]>
Mon, 4 Mar 2013 08:46:27 +0000 (16:46 +0800)
.htaccess [new file with mode: 0644]
fbcal.py [new file with mode: 0755]

diff --git a/.htaccess b/.htaccess
new file mode 100644 (file)
index 0000000..53afb60
--- /dev/null
+++ b/.htaccess
@@ -0,0 +1,13 @@
+AddHandler cgi-script .pl .py .cgi
+Options ExecCgi
+Options -Indexes
+
+<Files icalparse.py>
+       order allow,deny
+       deny from all
+</Files>
+
+<Files parserrules.py>
+       order allow,deny
+       deny from all
+</Files>
diff --git a/fbcal.py b/fbcal.py
new file mode 100755 (executable)
index 0000000..8068f5e
--- /dev/null
+++ b/fbcal.py
@@ -0,0 +1,58 @@
+#!/usr/bin/python
+#
+# Copyright (c) 2011 James French <[email protected]>
+#
+# Permission is hereby granted, free of charge, to any person obtaining a copy
+# of this software and associated documentation files (the "Software"), to deal
+# in the Software without restriction, including without limitation the rights
+# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+# copies of the Software, and to permit persons to whom the Software is
+# furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice shall be included in
+# all copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+# THE SOFTWARE.
+
+import sys
+import cgi
+import vobject
+import icalparse
+import re
+#import cgitb; cgitb.enable()
+
+def exitQuiet(exitstate=0):
+       print('Content-Type: text/html\n')
+       sys.exit(exitstate)
+
+if __name__ == '__main__':
+       form = cgi.FieldStorage()
+       if "uid" not in form or "key" not in form:
+               print('Content-Type: text/html\n')
+               sys.exit(0)
+       try:
+               # UID should be numeric, if it's not we have someone playing games
+               uid = int(form['uid'].value)
+       except:
+               exitQuiet()
+
+       # The user's key will be a 16 character alphanumeric string
+       key = form['key'].value
+       re.search('[\W_]+', key) and exitQuiet()
+       len(key) == 16 or exitQuiet()
+
+       # Okay, we're happy that the input is sane, lets serve up some data
+       url = 'http://www.facebook.com/ical/u.php?uid=%d&key=%s'%(uid,key)
+       (content, encoding) = icalparse.getHTTPContent(url)
+
+       cal = vobject.readOne(unicode(content, encoding))
+       cal = icalparse.applyRules(cal, icalparse.generateRules(), False)
+
+       print('Content-Type: text/calendar; charset=%s\n'%encoding)
+       icalparse.writeOutput(cal)

UCC git Repository :: git.ucc.asn.au