-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathremote_stub.py
49 lines (40 loc) · 1.61 KB
/
remote_stub.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#!/usr/bin/python
#Licensed under the GPLv2 (not later versions)
#see LICENSE.txt for details
# stub to prevent a ton of unneeded error messages in the appengine log
import os
import lindenip
import logging
from google.appengine.ext import db
from google.appengine.ext import webapp
from google.appengine.ext.webapp.util import run_wsgi_app
from model import AvTokenValue
class MainPage(webapp.RequestHandler):
def get(self):
#check linden ip
if lindenip.inrange(os.environ['REMOTE_ADDR']) != 'Production':
self.error(403)
elif self.request.headers['X-SecondLife-Shard'] != 'Production':
logging.warning("Attempt while on beta grid %s" % (self.request.headers['X-SecondLife-Shard']))
self.response.set_status(305)
else:
av = self.request.headers['X-SecondLife-Owner-Key']
record = AvTokenValue.gql("WHERE av = :1 AND token = 'owner'", av).get()
if record is not None:
owner = record.value.split(",")[0]
logging.warning('Remote disabled for %s' % self.request.headers['X-SecondLife-Owner-Name'])
self.response.out.write("remoteoff|%s" % owner)
else:
self.response.out.write("remoteoff|%s" % av)
logging.warning('Remote disabled for selfowned %s' % self.request.headers['X-SecondLife-Owner-Name'])
def put(self):
#check linden IP
self.response.out.write("")
application = webapp.WSGIApplication(
[('.*', MainPage)
],
debug=True)
def main():
run_wsgi_app(application)
if __name__ == "__main__":
main()