source: subversion/applications/editors/django/osmeditor/simple/views.py @ 13691

Last change on this file since 13691 was 13691, checked in by crschmidt, 10 years ago

fix key check

File size: 5.3 KB
Line 
1from django.conf import settings
2from django import forms
3from django.shortcuts import render_to_response
4from django.http import HttpResponse, HttpResponseRedirect
5from django.forms.util import ValidationError
6import urllib
7
8try:
9    import httplib2
10except:
11    from third import httplib2
12
13from lib import osmparser
14
15def osmparser_obj(type, id, xml=None):
16    if not xml:
17        xml = get_xml_string(type, id)
18    output = osmparser.parseString(xml, site_url=settings.OSM_SERVER)
19    return output["%ss" % type][int(id)] 
20
21def get_xml_string(type, id):
22    url = "%s/%s/%s/full" % (settings.OSM_API, type, id)
23    if type == "node":
24        url = url.replace('/full','') # required because the API 404s on node/x/full - wtf?
25    h = httplib2.Http()   
26    (resp, content) = h.request(url)
27    if int(resp.status) != 200:
28        raise Exception("%s returned %s" % (url, resp.status))
29    return content
30
31def edit_osm_obj(type, id, post, session={}):
32    obj = osmparser_obj(type, id)
33    if obj.timestamp != post['timestamp']:
34        raise Exception("Object changed since you started editing it.")
35   
36    if 'action' in post and post['action'] == "delete":
37        username = post.get('username', None) or session.get("username", None)
38        password = post.get('password', None) or session.get("password", None)
39        if not username or not password:
40            raise Exception("Need username and password")
41        id = obj.id   
42        obj.delete(username, password)
43        obj.id = id
44    else:
45        changed = False
46        for key in filter(lambda x: x.startswith("delete_"), post.keys()):
47            k = key.replace("delete_key_", "")
48            if k in obj.tags:
49                changed = True
50                del obj.tags[k]
51            else:
52                raise Exception("Huh? %s is not in tags" % k)
53       
54        for key in filter(lambda x: x.startswith("key_"), post.keys()):
55            k = key.replace("key_", "")
56            if k in obj.tags and post[key] != obj.tags[k]:
57                changed = True
58                obj.tags[k] = post[key]
59   
60        for key in filter(lambda x: x.startswith("new_key_"), post.keys()):
61            new_id = key.replace("new_key_", "")
62            kname = "new_key_%s" % new_id
63            vname = "new_value_%s" % new_id
64            if kname in post and vname in post:
65                k = post[kname]
66                v = post[vname]
67                if k and v:
68                    obj.tags[k] = v
69                    changed = True
70               
71        if changed:
72
73            username = post.get('username', None) or session.get("username", None)
74            password = post.get('password', None) or session.get("password", None)
75            if not username or not password:
76                raise Exception("Need username and password")
77            obj.save(username, password)
78    return obj
79
80def tag_sorter(a, b):
81    if ':' in a and not ':' in b:
82        return 1
83    elif ':' in b and not ':' in a:
84        return -1
85    return cmp(a,b)
86
87def load(request, type="node", id=0):
88    if request.method == "POST":
89        obj = edit_osm_obj(type, id, request.POST, request.session)
90        return HttpResponseRedirect(obj.local_url())   
91    xml = get_xml_string(type, id)
92    obj = osmparser_obj(type, id, xml=xml)
93   
94    tag_list = obj.tags.keys()
95    tag_list.sort(tag_sorter)
96    sorted_tags = []
97    for k in tag_list:
98        sorted_tags.append((k, obj.tags[k]))
99    return render_to_response("obj.html",{'obj':obj, 'obj_xml': xml, 
100        'sorted_tags': sorted_tags,
101        'logged_in': ('username' in request.session)})
102
103def home(request):
104    return render_to_response("home.html", {'logged_in': 'username' in request.session})
105
106class UserForm(forms.Form):
107    email = forms.CharField(max_length=255)
108    password = forms.CharField(widget=forms.PasswordInput)
109
110    def clean(self):
111        if self.cleaned_data.get('password') and self.cleaned_data.get('password'):
112            http = httplib2.Http()   
113            http.add_credentials(self.cleaned_data['email'], self.cleaned_data['password'])
114            url = "%s/user/details" % (settings.OSM_API)
115            resp, content = http.request(url, "GET")
116            if int(resp.status) == 200:
117                return self.cleaned_data
118            else:
119                raise ValidationError("Could not authenticate against OSM API") 
120                       
121
122def login(request):
123    if request.method == "POST":
124        form = UserForm(request.POST)
125        if form.is_valid():
126            request.session['username'] = form.cleaned_data['email']
127            request.session['password'] = form.cleaned_data['password']
128            return HttpResponseRedirect("/")
129    else:
130        form = UserForm()
131    return render_to_response("login.html", {'form': form})   
132
133def logout(request):
134    request.session.flush()
135    return HttpResponseRedirect("/")   
136
137def help(request):
138    return render_to_response("help.html")
139
140def api_proxy(request, url):
141    http = httplib2.Http()   
142    if 'username' in request.session:
143        http.add_credentials(request.session['username'], request.session['password'])
144    url = "%s/%s?%s" % (settings.OSM_API, url, urllib.urlencode(request.GET))
145    body = (request.raw_post_data or None)
146    resp, content = http.request(url, request.method, body=body)
147    return HttpResponse(content, content_type="application/osm+xml", status=resp.status)
Note: See TracBrowser for help on using the repository browser.