about summary refs log tree commit diff
path: root/app/assets/javascripts/components/link_header.jsx
diff options
context:
space:
mode:
authorEugen <eugen@zeonfederated.com>2017-04-11 22:53:58 +0200
committerGitHub <noreply@github.com>2017-04-11 22:53:58 +0200
commitb22b2cbfacdaef2441d14f401c95863d8ca2e66c (patch)
tree0fe5d26908e2ba5cea36a7698d06e4fdcfc52021 /app/assets/javascripts/components/link_header.jsx
parent2f2b84bfbbfa21a09e03dca05e159aadb70d2232 (diff)
Fix #1491 - Fix broken notifications, broken Link header parsing for exclude_types (#1548)
Diffstat (limited to 'app/assets/javascripts/components/link_header.jsx')
-rw-r--r--app/assets/javascripts/components/link_header.jsx33
1 files changed, 33 insertions, 0 deletions
diff --git a/app/assets/javascripts/components/link_header.jsx b/app/assets/javascripts/components/link_header.jsx
new file mode 100644
index 000000000..9a9ff7e7a
--- /dev/null
+++ b/app/assets/javascripts/components/link_header.jsx
@@ -0,0 +1,33 @@
+import Link from 'http-link-header';
+import querystring from 'querystring';
+
+Link.parseAttrs = (link, parts) => {
+  let match = null
+  let attr  = ''
+  let value = ''
+  let attrs = ''
+
+  let uriAttrs = /<(.*)>;\s*(.*)/gi.exec(parts)
+
+  if(uriAttrs) {
+    attrs = uriAttrs[2]
+    link  = Link.parseParams(link, uriAttrs[1])
+  }
+
+  while(match = Link.attrPattern.exec(attrs)) {
+    attr  = match[1].toLowerCase()
+    value = match[4] || match[3] || match[2]
+
+    if( /\*$/.test(attr)) {
+      Link.setAttr(link, attr, Link.parseExtendedValue(value))
+    } else if(/%/.test(value)) {
+      Link.setAttr(link, attr, querystring.decode(value))
+    } else {
+      Link.setAttr(link, attr, value)
+    }
+  }
+
+  return link
+};
+
+export default Link;