- Disabled CSRF authentication until OAuth authentication, since DRF leads to csrf error while handling sessionauthentication.
- Added general rest_api function to make request to apis and get response.
---
api/rest.py | 6 ++++++
patchew-cli | 34 ++++++++++++++++++++++++++++++++++
2 files changed, 40 insertions(+)
diff --git a/api/rest.py b/api/rest.py
index 9ec0ae8..45dab6e 100644
--- a/api/rest.py
+++ b/api/rest.py
@@ -25,6 +25,12 @@ from rest_framework.response import Response
import rest_framework
from mbox import addr_db_to_rest, MboxMessage
from rest_framework.parsers import JSONParser, BaseParser
+from rest_framework.authentication import SessionAuthentication
+
+class CsrfExemptSessionAuthentication(SessionAuthentication):
+
+ def enforce_csrf(self, request):
+ return # To not perform the csrf check previously happening
SEARCH_PARAM = 'q'
diff --git a/patchew-cli b/patchew-cli
index 174d1e6..2069885 100755
--- a/patchew-cli
+++ b/patchew-cli
@@ -92,6 +92,40 @@ class SubCommand(object):
r = None
return r
+ def rest_api_do(self, url_cmd, request_method='get', content_type=None, data=None):
+ logging.debug("API call '%s':" % url_cmd)
+ logging.debug("data:\n%s" % data)
+ cookie = http.cookiejar.MozillaCookieJar(COOKIE_FILENAME)
+ try:
+ cookie.load()
+ except IOError:
+ pass
+ except http.cookiejar.LoadError:
+ print("Error while loading cookie", COOKIE_FILENAME)
+ pass
+ handler = urllib.request.HTTPCookieProcessor(cookie)
+ opener = urllib.request.build_opener(handler)
+ if url_cmd.startswith("http"):
+ url = url_cmd
+ else:
+ url = self.base_url + '/api/v1/' + url_cmd + '/'
+ if data is None:
+ post_data = ""
+ else:
+ post_data = data
+ req = urllib.request.Request(url, data=bytes(post_data, encoding="utf-8"), method=request_method.upper())
+ if content_type is not None:
+ req.add_header('Content-Type', content_type)
+ resp = opener.open(req)
+ cookie.save(ignore_discard=True, ignore_expires=True)
+ respdata = resp.read()
+ logging.debug("Server response:\n%s" % (respdata or "<empty>"))
+ if respdata:
+ r = json.loads(respdata.decode("utf-8"))
+ else:
+ r = None
+ return r
+
def do(self, args, argv):
"""Do command"""
print("Not implemented")
--
2.15.1 (Apple Git-101)
_______________________________________________
Patchew-devel mailing list
Patchew-devel@redhat.com
https://www.redhat.com/mailman/listinfo/patchew-devel
On Sat, 07/07 00:02, Shubham Jain wrote: > - Disabled CSRF authentication until OAuth authentication, since DRF leads to csrf error while handling sessionauthentication. > - Added general rest_api function to make request to apis and get response. Please split these to two patches. > --- > api/rest.py | 6 ++++++ > patchew-cli | 34 ++++++++++++++++++++++++++++++++++ > 2 files changed, 40 insertions(+) > > diff --git a/api/rest.py b/api/rest.py > index 9ec0ae8..45dab6e 100644 > --- a/api/rest.py > +++ b/api/rest.py > @@ -25,6 +25,12 @@ from rest_framework.response import Response > import rest_framework > from mbox import addr_db_to_rest, MboxMessage > from rest_framework.parsers import JSONParser, BaseParser > +from rest_framework.authentication import SessionAuthentication > + > +class CsrfExemptSessionAuthentication(SessionAuthentication): > + > + def enforce_csrf(self, request): > + return # To not perform the csrf check previously happening > > SEARCH_PARAM = 'q' > > diff --git a/patchew-cli b/patchew-cli > index 174d1e6..2069885 100755 > --- a/patchew-cli > +++ b/patchew-cli > @@ -92,6 +92,40 @@ class SubCommand(object): > r = None > return r > > + def rest_api_do(self, url_cmd, request_method='get', content_type=None, data=None): > + logging.debug("API call '%s':" % url_cmd) > + logging.debug("data:\n%s" % data) > + cookie = http.cookiejar.MozillaCookieJar(COOKIE_FILENAME) > + try: > + cookie.load() > + except IOError: > + pass > + except http.cookiejar.LoadError: > + print("Error while loading cookie", COOKIE_FILENAME) > + pass > + handler = urllib.request.HTTPCookieProcessor(cookie) > + opener = urllib.request.build_opener(handler) > + if url_cmd.startswith("http"): > + url = url_cmd > + else: > + url = self.base_url + '/api/v1/' + url_cmd + '/' > + if data is None: > + post_data = "" > + else: > + post_data = data > + req = urllib.request.Request(url, data=bytes(post_data, encoding="utf-8"), method=request_method.upper()) > + if content_type is not None: > + req.add_header('Content-Type', content_type) > + resp = opener.open(req) > + cookie.save(ignore_discard=True, ignore_expires=True) > + respdata = resp.read() > + logging.debug("Server response:\n%s" % (respdata or "<empty>")) > + if respdata: > + r = json.loads(respdata.decode("utf-8")) > + else: > + r = None > + return r > + > def do(self, args, argv): > """Do command""" > print("Not implemented") > -- > 2.15.1 (Apple Git-101) > > _______________________________________________ > Patchew-devel mailing list > Patchew-devel@redhat.com > https://www.redhat.com/mailman/listinfo/patchew-devel _______________________________________________ Patchew-devel mailing list Patchew-devel@redhat.com https://www.redhat.com/mailman/listinfo/patchew-devel
© 2016 - 2025 Red Hat, Inc.