mirror of
https://github.com/openfoodfoundation/openfoodnetwork
synced 2026-03-07 03:01:33 +00:00
111 lines
146 KiB
YAML
111 lines
146 KiB
YAML
---
|
|
http_interactions:
|
|
- request:
|
|
method: post
|
|
uri: https://kc.cqcm.startinblox.com/realms/startinblox/protocol/openid-connect/token
|
|
body:
|
|
encoding: UTF-8
|
|
string: client_id=https%3A%2F%2Fstaging.openfoodnetwork.org.uk%2F&client_secret=<HIDDEN-OPENID_APP_SECRET>&grant_type=client_credentials&scope=WriteEnterprise
|
|
headers:
|
|
User-Agent:
|
|
- Faraday v2.9.0
|
|
Content-Type:
|
|
- application/x-www-form-urlencoded
|
|
Accept-Encoding:
|
|
- gzip;q=1.0,deflate;q=0.6,identity;q=0.3
|
|
Accept:
|
|
- "*/*"
|
|
response:
|
|
status:
|
|
code: 200
|
|
message: OK
|
|
headers:
|
|
Server:
|
|
- nginx/1.22.1
|
|
Date:
|
|
- Wed, 24 Sep 2025 04:08:53 GMT
|
|
Content-Type:
|
|
- application/json
|
|
Content-Length:
|
|
- '1726'
|
|
Connection:
|
|
- keep-alive
|
|
Cache-Control:
|
|
- no-store
|
|
Pragma:
|
|
- no-cache
|
|
Referrer-Policy:
|
|
- no-referrer
|
|
Strict-Transport-Security:
|
|
- max-age=31536000; includeSubDomains
|
|
X-Content-Type-Options:
|
|
- nosniff
|
|
X-Frame-Options:
|
|
- SAMEORIGIN
|
|
X-Xss-Protection:
|
|
- 1; mode=block
|
|
body:
|
|
encoding: UTF-8
|
|
string: '{"access_token":"<HIDDEN-OPENID-TOKEN>","expires_in":300,"refresh_expires_in":0,"token_type":"Bearer","not-before-policy":0,"scope":"WriteEnterprise
|
|
profile email"}'
|
|
recorded_at: Wed, 24 Sep 2025 04:08:53 GMT
|
|
- request:
|
|
method: post
|
|
uri: https://api.proxy-dev.cqcm.startinblox.com/djangoldp-dfc/webhook/
|
|
body:
|
|
encoding: UTF-8
|
|
string: '{"eventType":"refresh","enterpriseUrlid":"http://test.host/api/dfc/enterprises","scope":"ReadEnterprise"}'
|
|
headers:
|
|
Authorization:
|
|
- "<HIDDEN-AUTHORIZATION-HEADER>"
|
|
User-Agent:
|
|
- Faraday v2.9.0
|
|
Content-Type:
|
|
- application/json
|
|
Accept-Encoding:
|
|
- gzip;q=1.0,deflate;q=0.6,identity;q=0.3
|
|
Accept:
|
|
- "*/*"
|
|
response:
|
|
status:
|
|
code: 500
|
|
message: Internal Server Error
|
|
headers:
|
|
Connection:
|
|
- keep-alive
|
|
Content-Length:
|
|
- '110452'
|
|
Content-Type:
|
|
- text/html; charset=utf-8
|
|
Vary:
|
|
- Accept-Encoding, Cookie
|
|
Access-Control-Allow-Origin:
|
|
- None
|
|
Access-Control-Allow-Methods:
|
|
- GET,POST,PUT,PATCH,DELETE,OPTIONS,HEAD
|
|
Access-Control-Allow-Headers:
|
|
- authorization, Content-Type, if-match, accept, sentry-trace, DPoP, cache-control,
|
|
pragma, prefer, accept-model-fields, depth
|
|
Access-Control-Expose-Headers:
|
|
- Location, User
|
|
Access-Control-Allow-Credentials:
|
|
- 'true'
|
|
X-Frame-Options:
|
|
- DENY
|
|
X-Content-Type-Options:
|
|
- nosniff
|
|
Referrer-Policy:
|
|
- same-origin
|
|
Cross-Origin-Opener-Policy:
|
|
- same-origin
|
|
Via:
|
|
- 1.1 alproxy
|
|
Date:
|
|
- Wed, 24 Sep 2025 04:08:56 GMT
|
|
body:
|
|
encoding: ASCII-8BIT
|
|
string: !binary |-
|
|
<!DOCTYPE html>
<html lang="en">
<head>
  <meta http-equiv="content-type" content="text/html; charset=utf-8">
  <meta name="robots" content="NONE,NOARCHIVE">
  <title>JSONDecodeError
          at /djangoldp-dfc/webhook/</title>
  <style type="text/css">
    html * { padding:0; margin:0; }
    body * { padding:10px 20px; }
    body * * { padding:0; }
    body { font:small sans-serif; background-color:#fff; color:#000; }
    body>div { border-bottom:1px solid #ddd; }
    h1 { font-weight:normal; }
    h2 { margin-bottom:.8em; }
    h3 { margin:1em 0 .5em 0; }
    h4 { margin:0 0 .5em 0; font-weight: normal; }
    code, pre { font-size: 100%; white-space: pre-wrap; word-break: break-word; }
    summary { cursor: pointer; }
    table { border:1px solid #ccc; border-collapse: collapse; width:100%; background:white; }
    tbody td, tbody th { vertical-align:top; padding:2px 3px; }
    thead th {
      padding:1px 6px 1px 3px; background:#fefefe; text-align:left;
      font-weight:normal; font-size:11px; border:1px solid #ddd;
    }
    tbody th { width:12em; text-align:right; color:#666; padding-right:.5em; }
    table.vars { margin:5px 10px 2px 40px; width: auto; }
    table.vars td, table.req td { font-family:monospace; }
    table td.code { width:100%; }
    table td.code pre { overflow:hidden; }
    table.source th { color:#666; }
    table.source td { font-family:monospace; white-space:pre; border-bottom:1px solid #eee; }
    ul.traceback { list-style-type:none; color: #222; }
    ul.traceback li.cause { word-break: break-word; }
    ul.traceback li.frame { padding-bottom:1em; color:#4f4f4f; }
    ul.traceback li.user { background-color:#e0e0e0; color:#000 }
    div.context { padding:10px 0; overflow:hidden; }
    div.context ol { padding-left:30px; margin:0 10px; list-style-position: inside; }
    div.context ol li { font-family:monospace; white-space:pre; color:#777; cursor:pointer; padding-left: 2px; }
    div.context ol li pre { display:inline; }
    div.context ol.context-line li { color:#464646; background-color:#dfdfdf; padding: 3px 2px; }
    div.context ol.context-line li span { position:absolute; right:32px; }
    .user div.context ol.context-line li { background-color:#bbb; color:#000; }
    .user div.context ol li { color:#666; }
    div.commands, summary.commands { margin-left: 40px; }
    div.commands a, summary.commands { color:#555; text-decoration:none; }
    .user div.commands a { color: black; }
    #summary { background: #ffc; }
    #summary h2 { font-weight: normal; color: #666; }
    #explanation { background:#eee; }
    #template, #template-not-exist { background:#f6f6f6; }
    #template-not-exist ul { margin: 0 0 10px 20px; }
    #template-not-exist .postmortem-section { margin-bottom: 3px; }
    #unicode-hint { background:#eee; }
    #traceback { background:#eee; }
    #requestinfo { background:#f6f6f6; padding-left:120px; }
    #summary table { border:none; background:transparent; }
    #requestinfo h2, #requestinfo h3 { position:relative; margin-left:-100px; }
    #requestinfo h3 { margin-bottom:-1em; }
    .error { background: #ffc; }
    .specific { color:#cc3300; font-weight:bold; }
    h2 span.commands { font-size:.7em; font-weight:normal; }
    span.commands a:link {color:#5E5694;}
    pre.exception_value { font-family: sans-serif; color: #575757; font-size: 1.5em; margin: 10px 0 10px 0; }
    .append-bottom { margin-bottom: 10px; }
    .fname { user-select: all; }
  </style>
  
  <script>
    function hideAll(elems) {
      for (var e = 0; e < elems.length; e++) {
        elems[e].style.display = 'none';
      }
    }
    window.onload = function() {
      hideAll(document.querySelectorAll('ol.pre-context'));
      hideAll(document.querySelectorAll('ol.post-context'));
      hideAll(document.querySelectorAll('div.pastebin'));
    }
    function toggle() {
      for (var i = 0; i < arguments.length; i++) {
        var e = document.getElementById(arguments[i]);
        if (e) {
          e.style.display = e.style.display == 'none' ? 'block': 'none';
        }
      }
      return false;
    }
    function switchPastebinFriendly(link) {
      s1 = "Switch to copy-and-paste view";
      s2 = "Switch back to interactive view";
      link.textContent = link.textContent.trim() == s1 ? s2: s1;
      toggle('browserTraceback', 'pastebinTraceback');
      return false;
    }
  </script>
  
</head>
<body>
<div id="summary">
  <h1>JSONDecodeError
       at /djangoldp-dfc/webhook/</h1>
  <pre class="exception_value">Expecting value: line 1 column 1 (char 0)</pre>
  <table class="meta">

    <tr>
      <th>Request Method:</th>
      <td>POST</td>
    </tr>
    <tr>
      <th>Request URL:</th>
      <td>https://api.proxy-dev.cqcm.startinblox.com/djangoldp-dfc/webhook/</td>
    </tr>

    <tr>
      <th>Django Version:</th>
      <td>4.2.20</td>
    </tr>

    <tr>
      <th>Exception Type:</th>
      <td>JSONDecodeError</td>
    </tr>


    <tr>
      <th>Exception Value:</th>
      <td><pre>Expecting value: line 1 column 1 (char 0)</pre></td>
    </tr>


    <tr>
      <th>Exception Location:</th>
      <td><span class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/requests/models.py</span>, line 975, in json</td>
    </tr>


    <tr>
      <th>Raised during:</th>
      <td>data_food_consortium.views.CacheWebhookView</td>
    </tr>

    <tr>
      <th>Python Executable:</th>
      <td>/usr/alwaysdata/uwsgi/2.0.28/bin/uwsgi</td>
    </tr>
    <tr>
      <th>Python Version:</th>
      <td>3.11.13</td>
    </tr>
    <tr>
      <th>Python Path:</th>
      <td><pre>[&#x27;.&#x27;,
 &#x27;&#x27;,
 &#x27;/usr/alwaysdata/python/3.11/lib/python311.zip&#x27;,
 &#x27;/usr/alwaysdata/python/3.11/lib/python3.11&#x27;,
 &#x27;/usr/alwaysdata/python/3.11/lib/python3.11/lib-dynload&#x27;,
 &#x27;/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages&#x27;]</pre></td>
    </tr>
    <tr>
      <th>Server time:</th>
      <td>Wed, 24 Sep 2025 04:08:56 +0000</td>
    </tr>
  </table>
</div>




<div id="traceback">
  <h2>Traceback <span class="commands"><a href="#" onclick="return switchPastebinFriendly(this);">
    Switch to copy-and-paste view</a></span>
  </h2>
  <div id="browserTraceback">
    <ul class="traceback">
      
        
        <li class="frame user">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/requests/models.py</code>, line 971, in json
          

          
            <div class="context" id="c140515730447232">
              
                <ol start="964" class="pre-context" id="pre140515730447232">
                
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>                    # and the server didn&#x27;t bother to tell us what codec *was*</pre></li>
                
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>                    # used.</pre></li>
                
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>                    pass</pre></li>
                
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>                except JSONDecodeError as e:</pre></li>
                
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>                    raise RequestsJSONDecodeError(e.msg, e.doc, e.pos)</pre></li>
                
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>        try:</pre></li>
                
                </ol>
              
              <ol start="971" class="context-line">
                <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>            return complexjson.loads(self.text, **kwargs)
                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='972' class="post-context" id="post140515730447232">
                  
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>        except JSONDecodeError as e:</pre></li>
                  
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>            # Catch JSON-related errors and raise as requests.JSONDecodeError</pre></li>
                  
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>            # This aliases json.JSONDecodeError and simplejson.JSONDecodeError</pre></li>
                  
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>            raise RequestsJSONDecodeError(e.msg, e.doc, e.pos)</pre></li>
                  
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730447232', 'post140515730447232')"><pre>    @property</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730447232">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>kwargs</td>
                    <td class="code"><pre>{}</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;Response [200]&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/usr/alwaysdata/python/3.11/lib/python3.11/json/__init__.py</code>, line 346, in loads
          

          
            <div class="context" id="c140515730448960">
              
                <ol start="339" class="pre-context" id="pre140515730448960">
                
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>            raise TypeError(f&#x27;the JSON object must be str, bytes or bytearray, &#x27;</pre></li>
                
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>                            f&#x27;not {s.__class__.__name__}&#x27;)</pre></li>
                
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>        s = s.decode(detect_encoding(s), &#x27;surrogatepass&#x27;)</pre></li>
                
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>    if (cls is None and object_hook is None and</pre></li>
                
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>            parse_int is None and parse_float is None and</pre></li>
                
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>            parse_constant is None and object_pairs_hook is None and not kw):</pre></li>
                
                </ol>
              
              <ol start="346" class="context-line">
                <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>        return _default_decoder.decode(s)
                    ^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='347' class="post-context" id="post140515730448960">
                  
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>    if cls is None:</pre></li>
                  
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>        cls = JSONDecoder</pre></li>
                  
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>    if object_hook is not None:</pre></li>
                  
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>        kw[&#x27;object_hook&#x27;] = object_hook</pre></li>
                  
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>    if object_pairs_hook is not None:</pre></li>
                  
                  <li onclick="toggle('pre140515730448960', 'post140515730448960')"><pre>        kw[&#x27;object_pairs_hook&#x27;] = object_pairs_hook</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730448960">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>cls</td>
                    <td class="code"><pre>None</pre></td>
                  </tr>
                
                  <tr>
                    <td>kw</td>
                    <td class="code"><pre>{}</pre></td>
                  </tr>
                
                  <tr>
                    <td>object_hook</td>
                    <td class="code"><pre>None</pre></td>
                  </tr>
                
                  <tr>
                    <td>object_pairs_hook</td>
                    <td class="code"><pre>None</pre></td>
                  </tr>
                
                  <tr>
                    <td>parse_constant</td>
                    <td class="code"><pre>None</pre></td>
                  </tr>
                
                  <tr>
                    <td>parse_float</td>
                    <td class="code"><pre>None</pre></td>
                  </tr>
                
                  <tr>
                    <td>parse_int</td>
                    <td class="code"><pre>None</pre></td>
                  </tr>
                
                  <tr>
                    <td>s</td>
                    <td class="code"><pre>(&quot;&lt;html ng-csp=&#x27;no-unsafe-eval&#x27;&gt;\n&quot;
 &#x27;&lt;head&gt;\n&#x27;
 &quot;&lt;meta charset=&#x27;utf-8&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;width=device-width,initial-scale=1.0&#x27; name=&#x27;viewport&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;Open Food Network&#x27; property=&#x27;og:title&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;The Open Food Network software platform allows farmers to &quot;
 &#x27;sell produce online, at a price that works for them. It has been built &#x27;
 &#x27;specifically for selling food so it can handle tricky measures or stock &#x27;
 &#x27;levels that only food has - a dozen eggs, a bunch of parsley, a whole &#x27;
 &quot;chicken that varies in weight…&#x27; property=&#x27;og:description&#x27;&gt;\n&quot;
 &#x27;&lt;meta &#x27;
 &quot;content=&#x27;<HIDDEN-OPENID_APP_ID>rails/active_storage/blobs/redirect/eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBBMTFjQWc9PSIsImV4cCI6bnVsbCwicHVyIjoiYmxvYl9pZCJ9fQ==--61d32dd38ad896c1c7106c8d9e11d97907de7f9f/ofn-uk.png&#x27; &quot;
 &quot;property=&#x27;og:image&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;noindex&#x27; name=&#x27;robots&#x27;&gt;\n&quot;
 &#x27;&lt;title&gt;Welcome to Open Food Network&lt;/title&gt;\n&#x27;
 &#x27;&lt;link rel=&quot;icon&quot; type=&quot;image/x-icon&quot; href=&quot;/favicon-staging.ico&quot; /&gt;\n&#x27;
 &#x27;&lt;link &#x27;
 &quot;href=&#x27;https://fonts.googleapis.com/css?family=Roboto:400,300italic,400italic,300,700,700italic|Oswald:300,400,700&#x27; &quot;
 &quot;rel=&#x27;stylesheet&#x27; type=&#x27;text/css&#x27;&gt;\n&quot;
 &quot;&lt;link as=&#x27;font&#x27; crossorigin=&#x27;anonymous&#x27; &quot;
 &quot;href=&#x27;/packs/media/fonts/OFN-v2-c273037b3ba3ee8264bc67e31ea3d701.woff&#x27; &quot;
 &quot;rel=&#x27;preload&#x27;&gt;\n&quot;
 &#x27;&lt;script&gt;\n&#x27;
 &#x27;  var _mtm = window._mtm = window._mtm || [];\n&#x27;
 &quot;  _mtm.push({&#x27;mtm.startTime&#x27;: (new Date().getTime()), &#x27;event&#x27;: &quot;
 &quot;&#x27;mtm.Start&#x27;});\n&quot;
 &quot;  var d=document, g=d.createElement(&#x27;script&#x27;), &quot;
 &quot;s=d.getElementsByTagName(&#x27;script&#x27;)[0];\n&quot;
 &#x27;  var &#x27;
 &#x27;u=&quot;https://cdn.innocraft.cloud/openfoodnetwork.innocraft.cloud/container_7MAgWxhr.js&quot;;\n&#x27;
 &quot;  g.type=&#x27;text/javascript&#x27;; g.async=true; g.defer=true; g.src=u; &quot;
 &#x27;s.parentNode.insertBefore(g,s);\n&#x27;
 &#x27;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &#x27;&lt;link hreflang=&quot;en-gb&quot; &#x27;
 &#x27;href=&quot;<HIDDEN-OPENID_APP_ID>locales/en_GB&quot;&gt;\n&#x27;
 &#x27;&lt;link hreflang=&quot;cy&quot; &#x27;
 &#x27;href=&quot;<HIDDEN-OPENID_APP_ID>locales/cy&quot;&gt;\n&#x27;
 &#x27;&lt;link hreflang=&quot;en&quot; &#x27;
 &#x27;href=&quot;<HIDDEN-OPENID_APP_ID>locales/en&quot;&gt;\n&#x27;
 &#x27;&lt;link rel=&quot;stylesheet&quot; href=&quot;/packs/css/darkswarm-65787921.css&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot; media=&quot;screen&quot; /&gt;\n&#x27;
 &#x27;&lt;script src=&quot;/packs/js/application-c44133f0d61103cef05f.js&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot;&gt;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &quot;&lt;script src=&#x27;//d2wy8f7a9ursnm.cloudfront.net/v7/bugsnag.min.js&#x27;&gt;&lt;/script&gt;\n&quot;
 &#x27;&lt;script&gt;\n&#x27;
 &#x27;  Bugsnag.start({\n&#x27;
 &#x27;    apiKey: &quot;f6c4e285ecd7f5683793e8d3f4a3de77&quot;,\n&#x27;
 &#x27;    releaseStage: &quot;staging&quot;\n&#x27;
 &#x27;  })\n&#x27;
 &#x27;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &quot;&lt;script src=&#x27;https://js.stripe.com/v3/&#x27; type=&#x27;text/javascript&#x27;&gt;&lt;/script&gt;\n&quot;
 &#x27;\n&#x27;
 &#x27;&lt;script &#x27;
 &#x27;src=&quot;/assets/darkswarm/all-1833039ea81c025461300f59d2a6e3aa5f70e59df6b777fee4f616852cead500.js&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot;&gt;&lt;/script&gt;\n&#x27;
 &#x27;&lt;script &#x27;
 &#x27;src=&quot;/assets/web/all-1da1cc6fe6a50c600a4552a2cc1a45297623e3d517b0e95219ed51cd7f798342.js&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot;&gt;&lt;/script&gt;\n&#x27;
 &#x27;&lt;script&gt;\n&#x27;
 &#x27;  I18n.default_locale = &quot;en_GB&quot;;\n&#x27;
 &#x27;  I18n.base_locale = &quot;en&quot;;\n&#x27;
 &#x27;  I18n.locale = &quot;en_GB&quot;;\n&#x27;
 &#x27;  I18n.fallbacks = true;\n&#x27;
 &quot;  moment.locale([I18n.locale, &#x27;en&#x27;]);\n&quot;
 &#x27;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &#x27;&lt;meta name=&quot;csrf-param&quot; content=&quot;authenticity_token&quot; /&gt;\n&#x27;
 &#x27;&lt;meta name=&quot;csrf-token&quot; &#x27;
 &#x27;content=&quot;lxVg89absltICt7ZP_YMdr35DWykUoHryumIFM7TajlOUdsUXZ6RXlw3aQFlwL3_bfeJWgDC0LzrtbXQu6MBfw&quot; &#x27;
 &#x27;/&gt;\n&#x27;
 &quot;&lt;meta content=&#x27;no-cache&#x27; name=&#x27;turbo-cache-control&#x27;&gt;\n&quot;
 &#x27;&lt;meta name=&quot;action-cable-url&quot; content=&quot;/cable&quot; /&gt;\n&#x27;
 &#x27;&lt;/head&gt;\n&#x27;
 &quot;&lt;body body-scroll=&#x27;true&#x27; class=&#x27;off-canvas&#x27; data-turbo=&#x27;false&#x27;&gt;\n&quot;
 &quot;&lt;div class=&#x27;off-canvas-wrap&#x27; offcanvas&gt;\n&quot;
 &quot;&lt;div class=&#x27;fixed off-canvas-fixed&#x27;&gt;\n&quot;
 &quot;&lt;div ng-controller=&#x27;CartDropdownCtrl&#x27;&gt;\n&quot;
 &quot;&lt;nav class=&#x27;top-bar show-for-large-up&#x27;&gt;\n&quot;
 &quot;&lt;section class=&#x27;top-bar-section&#x27;&gt;\n&quot;
 &quot;&lt;ul class=&#x27;nav-logo&#x27;&gt;\n&quot;
 &quot;&lt;li class=&#x27;ofn-logo&#x27;&gt;\n&quot;
 &quot;&lt;a href=&#x27;/&#x27;&gt;\n&quot;
 &#x27;&lt;img &#x27;
 &quot;src=&#x27;<HIDDEN-OPENID_APP_ID>rails/active_storage/blobs/redirect/eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBBMTFjQWc9PSIsImV4cCI6bnVsbCwicHVyIjoiYmxvYl9pZCJ9fQ==--61d32dd38ad896c1c7106c8d9e11d97907de7f9f/ofn-uk.png&#x27;&gt;\n&quot;
 &#x27;&lt;/a&gt;\n&#x27;
 &#x27;&lt;/li&gt;\n&#x27;
 &quot;&lt;li class=&#x27;powered-by&#x27;&gt;\n&quot;
 &quot;&lt;img src=&#x27;/fa… &lt;trimmed 30135 bytes string&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/usr/alwaysdata/python/3.11/lib/python3.11/json/decoder.py</code>, line 337, in decode
          

          
            <div class="context" id="c140515730443520">
              
                <ol start="330" class="pre-context" id="pre140515730443520">
                
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre>    def decode(self, s, _w=WHITESPACE.match):</pre></li>
                
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre>        &quot;&quot;&quot;Return the Python representation of ``s`` (a ``str`` instance</pre></li>
                
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre>        containing a JSON document).</pre></li>
                
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre>        &quot;&quot;&quot;</pre></li>
                
                </ol>
              
              <ol start="337" class="context-line">
                <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre>        obj, end = self.raw_decode(s, idx=_w(s, 0).end())
                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='338' class="post-context" id="post140515730443520">
                  
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre>        end = _w(s, end).end()</pre></li>
                  
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre>        if end != len(s):</pre></li>
                  
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre>            raise JSONDecodeError(&quot;Extra data&quot;, s, end)</pre></li>
                  
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre>        return obj</pre></li>
                  
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730443520', 'post140515730443520')"><pre>    def raw_decode(self, s, idx=0):</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730443520">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>_w</td>
                    <td class="code"><pre>&lt;built-in method match of re.Pattern object at 0x7fcc672aedc0&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>s</td>
                    <td class="code"><pre>(&quot;&lt;html ng-csp=&#x27;no-unsafe-eval&#x27;&gt;\n&quot;
 &#x27;&lt;head&gt;\n&#x27;
 &quot;&lt;meta charset=&#x27;utf-8&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;width=device-width,initial-scale=1.0&#x27; name=&#x27;viewport&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;Open Food Network&#x27; property=&#x27;og:title&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;The Open Food Network software platform allows farmers to &quot;
 &#x27;sell produce online, at a price that works for them. It has been built &#x27;
 &#x27;specifically for selling food so it can handle tricky measures or stock &#x27;
 &#x27;levels that only food has - a dozen eggs, a bunch of parsley, a whole &#x27;
 &quot;chicken that varies in weight…&#x27; property=&#x27;og:description&#x27;&gt;\n&quot;
 &#x27;&lt;meta &#x27;
 &quot;content=&#x27;<HIDDEN-OPENID_APP_ID>rails/active_storage/blobs/redirect/eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBBMTFjQWc9PSIsImV4cCI6bnVsbCwicHVyIjoiYmxvYl9pZCJ9fQ==--61d32dd38ad896c1c7106c8d9e11d97907de7f9f/ofn-uk.png&#x27; &quot;
 &quot;property=&#x27;og:image&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;noindex&#x27; name=&#x27;robots&#x27;&gt;\n&quot;
 &#x27;&lt;title&gt;Welcome to Open Food Network&lt;/title&gt;\n&#x27;
 &#x27;&lt;link rel=&quot;icon&quot; type=&quot;image/x-icon&quot; href=&quot;/favicon-staging.ico&quot; /&gt;\n&#x27;
 &#x27;&lt;link &#x27;
 &quot;href=&#x27;https://fonts.googleapis.com/css?family=Roboto:400,300italic,400italic,300,700,700italic|Oswald:300,400,700&#x27; &quot;
 &quot;rel=&#x27;stylesheet&#x27; type=&#x27;text/css&#x27;&gt;\n&quot;
 &quot;&lt;link as=&#x27;font&#x27; crossorigin=&#x27;anonymous&#x27; &quot;
 &quot;href=&#x27;/packs/media/fonts/OFN-v2-c273037b3ba3ee8264bc67e31ea3d701.woff&#x27; &quot;
 &quot;rel=&#x27;preload&#x27;&gt;\n&quot;
 &#x27;&lt;script&gt;\n&#x27;
 &#x27;  var _mtm = window._mtm = window._mtm || [];\n&#x27;
 &quot;  _mtm.push({&#x27;mtm.startTime&#x27;: (new Date().getTime()), &#x27;event&#x27;: &quot;
 &quot;&#x27;mtm.Start&#x27;});\n&quot;
 &quot;  var d=document, g=d.createElement(&#x27;script&#x27;), &quot;
 &quot;s=d.getElementsByTagName(&#x27;script&#x27;)[0];\n&quot;
 &#x27;  var &#x27;
 &#x27;u=&quot;https://cdn.innocraft.cloud/openfoodnetwork.innocraft.cloud/container_7MAgWxhr.js&quot;;\n&#x27;
 &quot;  g.type=&#x27;text/javascript&#x27;; g.async=true; g.defer=true; g.src=u; &quot;
 &#x27;s.parentNode.insertBefore(g,s);\n&#x27;
 &#x27;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &#x27;&lt;link hreflang=&quot;en-gb&quot; &#x27;
 &#x27;href=&quot;<HIDDEN-OPENID_APP_ID>locales/en_GB&quot;&gt;\n&#x27;
 &#x27;&lt;link hreflang=&quot;cy&quot; &#x27;
 &#x27;href=&quot;<HIDDEN-OPENID_APP_ID>locales/cy&quot;&gt;\n&#x27;
 &#x27;&lt;link hreflang=&quot;en&quot; &#x27;
 &#x27;href=&quot;<HIDDEN-OPENID_APP_ID>locales/en&quot;&gt;\n&#x27;
 &#x27;&lt;link rel=&quot;stylesheet&quot; href=&quot;/packs/css/darkswarm-65787921.css&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot; media=&quot;screen&quot; /&gt;\n&#x27;
 &#x27;&lt;script src=&quot;/packs/js/application-c44133f0d61103cef05f.js&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot;&gt;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &quot;&lt;script src=&#x27;//d2wy8f7a9ursnm.cloudfront.net/v7/bugsnag.min.js&#x27;&gt;&lt;/script&gt;\n&quot;
 &#x27;&lt;script&gt;\n&#x27;
 &#x27;  Bugsnag.start({\n&#x27;
 &#x27;    apiKey: &quot;f6c4e285ecd7f5683793e8d3f4a3de77&quot;,\n&#x27;
 &#x27;    releaseStage: &quot;staging&quot;\n&#x27;
 &#x27;  })\n&#x27;
 &#x27;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &quot;&lt;script src=&#x27;https://js.stripe.com/v3/&#x27; type=&#x27;text/javascript&#x27;&gt;&lt;/script&gt;\n&quot;
 &#x27;\n&#x27;
 &#x27;&lt;script &#x27;
 &#x27;src=&quot;/assets/darkswarm/all-1833039ea81c025461300f59d2a6e3aa5f70e59df6b777fee4f616852cead500.js&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot;&gt;&lt;/script&gt;\n&#x27;
 &#x27;&lt;script &#x27;
 &#x27;src=&quot;/assets/web/all-1da1cc6fe6a50c600a4552a2cc1a45297623e3d517b0e95219ed51cd7f798342.js&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot;&gt;&lt;/script&gt;\n&#x27;
 &#x27;&lt;script&gt;\n&#x27;
 &#x27;  I18n.default_locale = &quot;en_GB&quot;;\n&#x27;
 &#x27;  I18n.base_locale = &quot;en&quot;;\n&#x27;
 &#x27;  I18n.locale = &quot;en_GB&quot;;\n&#x27;
 &#x27;  I18n.fallbacks = true;\n&#x27;
 &quot;  moment.locale([I18n.locale, &#x27;en&#x27;]);\n&quot;
 &#x27;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &#x27;&lt;meta name=&quot;csrf-param&quot; content=&quot;authenticity_token&quot; /&gt;\n&#x27;
 &#x27;&lt;meta name=&quot;csrf-token&quot; &#x27;
 &#x27;content=&quot;lxVg89absltICt7ZP_YMdr35DWykUoHryumIFM7TajlOUdsUXZ6RXlw3aQFlwL3_bfeJWgDC0LzrtbXQu6MBfw&quot; &#x27;
 &#x27;/&gt;\n&#x27;
 &quot;&lt;meta content=&#x27;no-cache&#x27; name=&#x27;turbo-cache-control&#x27;&gt;\n&quot;
 &#x27;&lt;meta name=&quot;action-cable-url&quot; content=&quot;/cable&quot; /&gt;\n&#x27;
 &#x27;&lt;/head&gt;\n&#x27;
 &quot;&lt;body body-scroll=&#x27;true&#x27; class=&#x27;off-canvas&#x27; data-turbo=&#x27;false&#x27;&gt;\n&quot;
 &quot;&lt;div class=&#x27;off-canvas-wrap&#x27; offcanvas&gt;\n&quot;
 &quot;&lt;div class=&#x27;fixed off-canvas-fixed&#x27;&gt;\n&quot;
 &quot;&lt;div ng-controller=&#x27;CartDropdownCtrl&#x27;&gt;\n&quot;
 &quot;&lt;nav class=&#x27;top-bar show-for-large-up&#x27;&gt;\n&quot;
 &quot;&lt;section class=&#x27;top-bar-section&#x27;&gt;\n&quot;
 &quot;&lt;ul class=&#x27;nav-logo&#x27;&gt;\n&quot;
 &quot;&lt;li class=&#x27;ofn-logo&#x27;&gt;\n&quot;
 &quot;&lt;a href=&#x27;/&#x27;&gt;\n&quot;
 &#x27;&lt;img &#x27;
 &quot;src=&#x27;<HIDDEN-OPENID_APP_ID>rails/active_storage/blobs/redirect/eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBBMTFjQWc9PSIsImV4cCI6bnVsbCwicHVyIjoiYmxvYl9pZCJ9fQ==--61d32dd38ad896c1c7106c8d9e11d97907de7f9f/ofn-uk.png&#x27;&gt;\n&quot;
 &#x27;&lt;/a&gt;\n&#x27;
 &#x27;&lt;/li&gt;\n&#x27;
 &quot;&lt;li class=&#x27;powered-by&#x27;&gt;\n&quot;
 &quot;&lt;img src=&#x27;/fa… &lt;trimmed 30135 bytes string&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;json.decoder.JSONDecoder object at 0x7fcc672cdf50&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/usr/alwaysdata/python/3.11/lib/python3.11/json/decoder.py</code>, line 355, in raw_decode
          

          
            <div class="context" id="c140515728474880">
              
                <ol start="348" class="pre-context" id="pre140515728474880">
                
                  <li onclick="toggle('pre140515728474880', 'post140515728474880')"><pre>        This can be used to decode a JSON document from a string that may</pre></li>
                
                  <li onclick="toggle('pre140515728474880', 'post140515728474880')"><pre>        have extraneous data at the end.</pre></li>
                
                  <li onclick="toggle('pre140515728474880', 'post140515728474880')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515728474880', 'post140515728474880')"><pre>        &quot;&quot;&quot;</pre></li>
                
                  <li onclick="toggle('pre140515728474880', 'post140515728474880')"><pre>        try:</pre></li>
                
                  <li onclick="toggle('pre140515728474880', 'post140515728474880')"><pre>            obj, end = self.scan_once(s, idx)</pre></li>
                
                  <li onclick="toggle('pre140515728474880', 'post140515728474880')"><pre>        except StopIteration as err:</pre></li>
                
                </ol>
              
              <ol start="355" class="context-line">
                <li onclick="toggle('pre140515728474880', 'post140515728474880')"><pre>            raise JSONDecodeError(&quot;Expecting value&quot;, s, err.value) from None
                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='356' class="post-context" id="post140515728474880">
                  
                  <li onclick="toggle('pre140515728474880', 'post140515728474880')"><pre>        return obj, end</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515728474880">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>idx</td>
                    <td class="code"><pre>0</pre></td>
                  </tr>
                
                  <tr>
                    <td>s</td>
                    <td class="code"><pre>(&quot;&lt;html ng-csp=&#x27;no-unsafe-eval&#x27;&gt;\n&quot;
 &#x27;&lt;head&gt;\n&#x27;
 &quot;&lt;meta charset=&#x27;utf-8&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;width=device-width,initial-scale=1.0&#x27; name=&#x27;viewport&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;Open Food Network&#x27; property=&#x27;og:title&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;The Open Food Network software platform allows farmers to &quot;
 &#x27;sell produce online, at a price that works for them. It has been built &#x27;
 &#x27;specifically for selling food so it can handle tricky measures or stock &#x27;
 &#x27;levels that only food has - a dozen eggs, a bunch of parsley, a whole &#x27;
 &quot;chicken that varies in weight…&#x27; property=&#x27;og:description&#x27;&gt;\n&quot;
 &#x27;&lt;meta &#x27;
 &quot;content=&#x27;<HIDDEN-OPENID_APP_ID>rails/active_storage/blobs/redirect/eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBBMTFjQWc9PSIsImV4cCI6bnVsbCwicHVyIjoiYmxvYl9pZCJ9fQ==--61d32dd38ad896c1c7106c8d9e11d97907de7f9f/ofn-uk.png&#x27; &quot;
 &quot;property=&#x27;og:image&#x27;&gt;\n&quot;
 &quot;&lt;meta content=&#x27;noindex&#x27; name=&#x27;robots&#x27;&gt;\n&quot;
 &#x27;&lt;title&gt;Welcome to Open Food Network&lt;/title&gt;\n&#x27;
 &#x27;&lt;link rel=&quot;icon&quot; type=&quot;image/x-icon&quot; href=&quot;/favicon-staging.ico&quot; /&gt;\n&#x27;
 &#x27;&lt;link &#x27;
 &quot;href=&#x27;https://fonts.googleapis.com/css?family=Roboto:400,300italic,400italic,300,700,700italic|Oswald:300,400,700&#x27; &quot;
 &quot;rel=&#x27;stylesheet&#x27; type=&#x27;text/css&#x27;&gt;\n&quot;
 &quot;&lt;link as=&#x27;font&#x27; crossorigin=&#x27;anonymous&#x27; &quot;
 &quot;href=&#x27;/packs/media/fonts/OFN-v2-c273037b3ba3ee8264bc67e31ea3d701.woff&#x27; &quot;
 &quot;rel=&#x27;preload&#x27;&gt;\n&quot;
 &#x27;&lt;script&gt;\n&#x27;
 &#x27;  var _mtm = window._mtm = window._mtm || [];\n&#x27;
 &quot;  _mtm.push({&#x27;mtm.startTime&#x27;: (new Date().getTime()), &#x27;event&#x27;: &quot;
 &quot;&#x27;mtm.Start&#x27;});\n&quot;
 &quot;  var d=document, g=d.createElement(&#x27;script&#x27;), &quot;
 &quot;s=d.getElementsByTagName(&#x27;script&#x27;)[0];\n&quot;
 &#x27;  var &#x27;
 &#x27;u=&quot;https://cdn.innocraft.cloud/openfoodnetwork.innocraft.cloud/container_7MAgWxhr.js&quot;;\n&#x27;
 &quot;  g.type=&#x27;text/javascript&#x27;; g.async=true; g.defer=true; g.src=u; &quot;
 &#x27;s.parentNode.insertBefore(g,s);\n&#x27;
 &#x27;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &#x27;&lt;link hreflang=&quot;en-gb&quot; &#x27;
 &#x27;href=&quot;<HIDDEN-OPENID_APP_ID>locales/en_GB&quot;&gt;\n&#x27;
 &#x27;&lt;link hreflang=&quot;cy&quot; &#x27;
 &#x27;href=&quot;<HIDDEN-OPENID_APP_ID>locales/cy&quot;&gt;\n&#x27;
 &#x27;&lt;link hreflang=&quot;en&quot; &#x27;
 &#x27;href=&quot;<HIDDEN-OPENID_APP_ID>locales/en&quot;&gt;\n&#x27;
 &#x27;&lt;link rel=&quot;stylesheet&quot; href=&quot;/packs/css/darkswarm-65787921.css&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot; media=&quot;screen&quot; /&gt;\n&#x27;
 &#x27;&lt;script src=&quot;/packs/js/application-c44133f0d61103cef05f.js&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot;&gt;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &quot;&lt;script src=&#x27;//d2wy8f7a9ursnm.cloudfront.net/v7/bugsnag.min.js&#x27;&gt;&lt;/script&gt;\n&quot;
 &#x27;&lt;script&gt;\n&#x27;
 &#x27;  Bugsnag.start({\n&#x27;
 &#x27;    apiKey: &quot;f6c4e285ecd7f5683793e8d3f4a3de77&quot;,\n&#x27;
 &#x27;    releaseStage: &quot;staging&quot;\n&#x27;
 &#x27;  })\n&#x27;
 &#x27;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &quot;&lt;script src=&#x27;https://js.stripe.com/v3/&#x27; type=&#x27;text/javascript&#x27;&gt;&lt;/script&gt;\n&quot;
 &#x27;\n&#x27;
 &#x27;&lt;script &#x27;
 &#x27;src=&quot;/assets/darkswarm/all-1833039ea81c025461300f59d2a6e3aa5f70e59df6b777fee4f616852cead500.js&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot;&gt;&lt;/script&gt;\n&#x27;
 &#x27;&lt;script &#x27;
 &#x27;src=&quot;/assets/web/all-1da1cc6fe6a50c600a4552a2cc1a45297623e3d517b0e95219ed51cd7f798342.js&quot; &#x27;
 &#x27;data-turbo-track=&quot;reload&quot;&gt;&lt;/script&gt;\n&#x27;
 &#x27;&lt;script&gt;\n&#x27;
 &#x27;  I18n.default_locale = &quot;en_GB&quot;;\n&#x27;
 &#x27;  I18n.base_locale = &quot;en&quot;;\n&#x27;
 &#x27;  I18n.locale = &quot;en_GB&quot;;\n&#x27;
 &#x27;  I18n.fallbacks = true;\n&#x27;
 &quot;  moment.locale([I18n.locale, &#x27;en&#x27;]);\n&quot;
 &#x27;&lt;/script&gt;\n&#x27;
 &#x27;\n&#x27;
 &#x27;&lt;meta name=&quot;csrf-param&quot; content=&quot;authenticity_token&quot; /&gt;\n&#x27;
 &#x27;&lt;meta name=&quot;csrf-token&quot; &#x27;
 &#x27;content=&quot;lxVg89absltICt7ZP_YMdr35DWykUoHryumIFM7TajlOUdsUXZ6RXlw3aQFlwL3_bfeJWgDC0LzrtbXQu6MBfw&quot; &#x27;
 &#x27;/&gt;\n&#x27;
 &quot;&lt;meta content=&#x27;no-cache&#x27; name=&#x27;turbo-cache-control&#x27;&gt;\n&quot;
 &#x27;&lt;meta name=&quot;action-cable-url&quot; content=&quot;/cable&quot; /&gt;\n&#x27;
 &#x27;&lt;/head&gt;\n&#x27;
 &quot;&lt;body body-scroll=&#x27;true&#x27; class=&#x27;off-canvas&#x27; data-turbo=&#x27;false&#x27;&gt;\n&quot;
 &quot;&lt;div class=&#x27;off-canvas-wrap&#x27; offcanvas&gt;\n&quot;
 &quot;&lt;div class=&#x27;fixed off-canvas-fixed&#x27;&gt;\n&quot;
 &quot;&lt;div ng-controller=&#x27;CartDropdownCtrl&#x27;&gt;\n&quot;
 &quot;&lt;nav class=&#x27;top-bar show-for-large-up&#x27;&gt;\n&quot;
 &quot;&lt;section class=&#x27;top-bar-section&#x27;&gt;\n&quot;
 &quot;&lt;ul class=&#x27;nav-logo&#x27;&gt;\n&quot;
 &quot;&lt;li class=&#x27;ofn-logo&#x27;&gt;\n&quot;
 &quot;&lt;a href=&#x27;/&#x27;&gt;\n&quot;
 &#x27;&lt;img &#x27;
 &quot;src=&#x27;<HIDDEN-OPENID_APP_ID>rails/active_storage/blobs/redirect/eyJfcmFpbHMiOnsibWVzc2FnZSI6IkJBaHBBMTFjQWc9PSIsImV4cCI6bnVsbCwicHVyIjoiYmxvYl9pZCJ9fQ==--61d32dd38ad896c1c7106c8d9e11d97907de7f9f/ofn-uk.png&#x27;&gt;\n&quot;
 &#x27;&lt;/a&gt;\n&#x27;
 &#x27;&lt;/li&gt;\n&#x27;
 &quot;&lt;li class=&#x27;powered-by&#x27;&gt;\n&quot;
 &quot;&lt;img src=&#x27;/fa… &lt;trimmed 30135 bytes string&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;json.decoder.JSONDecoder object at 0x7fcc672cdf50&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
          <li class="cause"><h3>
          
            During handling of the above exception (Expecting value: line 1 column 1 (char 0)), another exception occurred:
          
        </h3></li>
        
        <li class="frame django">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/django/core/handlers/exception.py</code>, line 55, in inner
          

          
            <div class="context" id="c140515730383296">
              
                <ol start="48" class="pre-context" id="pre140515730383296">
                
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre>        return inner</pre></li>
                
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre>    else:</pre></li>
                
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre>        @wraps(get_response)</pre></li>
                
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre>        def inner(request):</pre></li>
                
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre>            try:</pre></li>
                
                </ol>
              
              <ol start="55" class="context-line">
                <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre>                response = get_response(request)
                               ^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='56' class="post-context" id="post140515730383296">
                  
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre>            except Exception as exc:</pre></li>
                  
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre>                response = response_for_exception(request, exc)</pre></li>
                  
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre>            return response</pre></li>
                  
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre>        return inner</pre></li>
                  
                  <li onclick="toggle('pre140515730383296', 'post140515730383296')"><pre></pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730383296">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>exc</td>
                    <td class="code"><pre>JSONDecodeError(&#x27;Expecting value: line 1 column 1 (char 0)&#x27;)</pre></td>
                  </tr>
                
                  <tr>
                    <td>get_response</td>
                    <td class="code"><pre>&lt;bound method BaseHandler._get_response of &lt;django.core.handlers.wsgi.WSGIHandler object at 0x7fcc652bcdd0&gt;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>request</td>
                    <td class="code"><pre>&lt;WSGIRequest: POST &#x27;/djangoldp-dfc/webhook/&#x27;&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame django">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/django/core/handlers/base.py</code>, line 197, in _get_response
          

          
            <div class="context" id="c140515730382528">
              
                <ol start="190" class="pre-context" id="pre140515730382528">
                
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>        if response is None:</pre></li>
                
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>            wrapped_callback = self.make_view_atomic(callback)</pre></li>
                
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>            # If it is an asynchronous view, run it in a subthread.</pre></li>
                
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>            if iscoroutinefunction(wrapped_callback):</pre></li>
                
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>                wrapped_callback = async_to_sync(wrapped_callback)</pre></li>
                
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>            try:</pre></li>
                
                </ol>
              
              <ol start="197" class="context-line">
                <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>                response = wrapped_callback(request, *callback_args, **callback_kwargs)
                                ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='198' class="post-context" id="post140515730382528">
                  
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>            except Exception as e:</pre></li>
                  
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>                response = self.process_exception_by_middleware(e, request)</pre></li>
                  
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>                if response is None:</pre></li>
                  
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>                    raise</pre></li>
                  
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730382528', 'post140515730382528')"><pre>        # Complain if the view returned None (a common error).</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730382528">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>callback</td>
                    <td class="code"><pre>&lt;function View.as_view.&lt;locals&gt;.view at 0x7fcc5eca4400&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>callback_args</td>
                    <td class="code"><pre>()</pre></td>
                  </tr>
                
                  <tr>
                    <td>callback_kwargs</td>
                    <td class="code"><pre>{}</pre></td>
                  </tr>
                
                  <tr>
                    <td>middleware_method</td>
                    <td class="code"><pre>&lt;bound method CsrfViewMiddleware.process_view of &lt;CsrfViewMiddleware get_response=convert_exception_to_response.&lt;locals&gt;.inner&gt;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>request</td>
                    <td class="code"><pre>&lt;WSGIRequest: POST &#x27;/djangoldp-dfc/webhook/&#x27;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>response</td>
                    <td class="code"><pre>None</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;django.core.handlers.wsgi.WSGIHandler object at 0x7fcc652bcdd0&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>wrapped_callback</td>
                    <td class="code"><pre>&lt;function View.as_view.&lt;locals&gt;.view at 0x7fcc5eca4400&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame django">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/django/views/decorators/csrf.py</code>, line 56, in wrapper_view
          

          
            <div class="context" id="c140515730383360">
              
                <ol start="49" class="pre-context" id="pre140515730383360">
                
                  <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre>def csrf_exempt(view_func):</pre></li>
                
                  <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre>    &quot;&quot;&quot;Mark a view function as being exempt from the CSRF view protection.&quot;&quot;&quot;</pre></li>
                
                  <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre>    # view_func.csrf_exempt = True would also work, but decorators are nicer</pre></li>
                
                  <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre>    # if they don&#x27;t have side effects, so return a new function.</pre></li>
                
                  <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre>    @wraps(view_func)</pre></li>
                
                  <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre>    def wrapper_view(*args, **kwargs):</pre></li>
                
                </ol>
              
              <ol start="56" class="context-line">
                <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre>        return view_func(*args, **kwargs)
                   ^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='57' class="post-context" id="post140515730383360">
                  
                  <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre>    wrapper_view.csrf_exempt = True</pre></li>
                  
                  <li onclick="toggle('pre140515730383360', 'post140515730383360')"><pre>    return wrapper_view</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730383360">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>args</td>
                    <td class="code"><pre>(&lt;WSGIRequest: POST &#x27;/djangoldp-dfc/webhook/&#x27;&gt;,)</pre></td>
                  </tr>
                
                  <tr>
                    <td>kwargs</td>
                    <td class="code"><pre>{}</pre></td>
                  </tr>
                
                  <tr>
                    <td>view_func</td>
                    <td class="code"><pre>&lt;function View.as_view.&lt;locals&gt;.view at 0x7fcc5eca4360&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame django">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/django/views/generic/base.py</code>, line 104, in view
          

          
            <div class="context" id="c140515730377280">
              
                <ol start="97" class="pre-context" id="pre140515730377280">
                
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>            self = cls(**initkwargs)</pre></li>
                
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>            self.setup(request, *args, **kwargs)</pre></li>
                
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>            if not hasattr(self, &quot;request&quot;):</pre></li>
                
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>                raise AttributeError(</pre></li>
                
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>                    &quot;%s instance has no &#x27;request&#x27; attribute. Did you override &quot;</pre></li>
                
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>                    &quot;setup() and forget to call super()?&quot; % cls.__name__</pre></li>
                
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>                )</pre></li>
                
                </ol>
              
              <ol start="104" class="context-line">
                <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>            return self.dispatch(request, *args, **kwargs)
                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='105' class="post-context" id="post140515730377280">
                  
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>        view.view_class = cls</pre></li>
                  
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>        view.view_initkwargs = initkwargs</pre></li>
                  
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>        # __name__ and __qualname__ are intentionally left unchanged as</pre></li>
                  
                  <li onclick="toggle('pre140515730377280', 'post140515730377280')"><pre>        # view_class should be used to robustly determine the name of the view</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730377280">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>args</td>
                    <td class="code"><pre>()</pre></td>
                  </tr>
                
                  <tr>
                    <td>cls</td>
                    <td class="code"><pre>&lt;class &#x27;data_food_consortium.views.CacheWebhookView&#x27;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>initkwargs</td>
                    <td class="code"><pre>{}</pre></td>
                  </tr>
                
                  <tr>
                    <td>kwargs</td>
                    <td class="code"><pre>{}</pre></td>
                  </tr>
                
                  <tr>
                    <td>request</td>
                    <td class="code"><pre>&lt;WSGIRequest: POST &#x27;/djangoldp-dfc/webhook/&#x27;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;data_food_consortium.views.CacheWebhookView object at 0x7fcc5e31c910&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/rest_framework/views.py</code>, line 509, in dispatch
          

          
            <div class="context" id="c140515730382016">
              
                <ol start="502" class="pre-context" id="pre140515730382016">
                
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre>                                  self.http_method_not_allowed)</pre></li>
                
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre>            else:</pre></li>
                
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre>                handler = self.http_method_not_allowed</pre></li>
                
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre>            response = handler(request, *args, **kwargs)</pre></li>
                
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre>        except Exception as exc:</pre></li>
                
                </ol>
              
              <ol start="509" class="context-line">
                <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre>            response = self.handle_exception(exc)
                            ^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='510' class="post-context" id="post140515730382016">
                  
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre>        self.response = self.finalize_response(request, response, *args, **kwargs)</pre></li>
                  
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre>        return self.response</pre></li>
                  
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre>    def options(self, request, *args, **kwargs):</pre></li>
                  
                  <li onclick="toggle('pre140515730382016', 'post140515730382016')"><pre>        &quot;&quot;&quot;</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730382016">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>args</td>
                    <td class="code"><pre>()</pre></td>
                  </tr>
                
                  <tr>
                    <td>handler</td>
                    <td class="code"><pre>&lt;bound method CacheWebhookView.post of &lt;data_food_consortium.views.CacheWebhookView object at 0x7fcc5e31c910&gt;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>kwargs</td>
                    <td class="code"><pre>{}</pre></td>
                  </tr>
                
                  <tr>
                    <td>request</td>
                    <td class="code"><pre>&lt;rest_framework.request.Request: POST &#x27;/djangoldp-dfc/webhook/&#x27;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;data_food_consortium.views.CacheWebhookView object at 0x7fcc5e31c910&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/rest_framework/views.py</code>, line 469, in handle_exception
          

          
            <div class="context" id="c140515730383808">
              
                <ol start="462" class="pre-context" id="pre140515730383808">
                
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre>        exception_handler = self.get_exception_handler()</pre></li>
                
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre>        context = self.get_exception_handler_context()</pre></li>
                
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre>        response = exception_handler(exc, context)</pre></li>
                
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre>        if response is None:</pre></li>
                
                </ol>
              
              <ol start="469" class="context-line">
                <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre>            self.raise_uncaught_exception(exc)
                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='470' class="post-context" id="post140515730383808">
                  
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre>        response.exception = True</pre></li>
                  
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre>        return response</pre></li>
                  
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre>    def raise_uncaught_exception(self, exc):</pre></li>
                  
                  <li onclick="toggle('pre140515730383808', 'post140515730383808')"><pre>        if settings.DEBUG:</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730383808">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>context</td>
                    <td class="code"><pre>{&#x27;args&#x27;: (),
 &#x27;kwargs&#x27;: {},
 &#x27;request&#x27;: &lt;rest_framework.request.Request: POST &#x27;/djangoldp-dfc/webhook/&#x27;&gt;,
 &#x27;view&#x27;: &lt;data_food_consortium.views.CacheWebhookView object at 0x7fcc5e31c910&gt;}</pre></td>
                  </tr>
                
                  <tr>
                    <td>exc</td>
                    <td class="code"><pre>JSONDecodeError(&#x27;Expecting value: line 1 column 1 (char 0)&#x27;)</pre></td>
                  </tr>
                
                  <tr>
                    <td>exception_handler</td>
                    <td class="code"><pre>&lt;function exception_handler at 0x7fcc65364c20&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>response</td>
                    <td class="code"><pre>None</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;data_food_consortium.views.CacheWebhookView object at 0x7fcc5e31c910&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/rest_framework/views.py</code>, line 480, in raise_uncaught_exception
          

          
            <div class="context" id="c140515730376128">
              
                <ol start="473" class="pre-context" id="pre140515730376128">
                
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>    def raise_uncaught_exception(self, exc):</pre></li>
                
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>        if settings.DEBUG:</pre></li>
                
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>            request = self.request</pre></li>
                
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>            renderer_format = getattr(request.accepted_renderer, &#x27;format&#x27;)</pre></li>
                
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>            use_plaintext_traceback = renderer_format not in (&#x27;html&#x27;, &#x27;api&#x27;, &#x27;admin&#x27;)</pre></li>
                
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>            request.force_plaintext_errors(use_plaintext_traceback)</pre></li>
                
                </ol>
              
              <ol start="480" class="context-line">
                <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>        raise exc
             ^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='481' class="post-context" id="post140515730376128">
                  
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>    # Note: Views are made CSRF exempt from within `as_view` as to prevent</pre></li>
                  
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>    # accidental removal of this exemption in cases where `dispatch` needs to</pre></li>
                  
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>    # be overridden.</pre></li>
                  
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>    def dispatch(self, request, *args, **kwargs):</pre></li>
                  
                  <li onclick="toggle('pre140515730376128', 'post140515730376128')"><pre>        &quot;&quot;&quot;</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730376128">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>exc</td>
                    <td class="code"><pre>JSONDecodeError(&#x27;Expecting value: line 1 column 1 (char 0)&#x27;)</pre></td>
                  </tr>
                
                  <tr>
                    <td>renderer_format</td>
                    <td class="code"><pre>&#x27;json&#x27;</pre></td>
                  </tr>
                
                  <tr>
                    <td>request</td>
                    <td class="code"><pre>&lt;rest_framework.request.Request: POST &#x27;/djangoldp-dfc/webhook/&#x27;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;data_food_consortium.views.CacheWebhookView object at 0x7fcc5e31c910&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>use_plaintext_traceback</td>
                    <td class="code"><pre>True</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/rest_framework/views.py</code>, line 506, in dispatch
          

          
            <div class="context" id="c140515730382848">
              
                <ol start="499" class="pre-context" id="pre140515730382848">
                
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>            # Get the appropriate handler method</pre></li>
                
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>            if request.method.lower() in self.http_method_names:</pre></li>
                
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>                handler = getattr(self, request.method.lower(),</pre></li>
                
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>                                  self.http_method_not_allowed)</pre></li>
                
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>            else:</pre></li>
                
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>                handler = self.http_method_not_allowed</pre></li>
                
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre></pre></li>
                
                </ol>
              
              <ol start="506" class="context-line">
                <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>            response = handler(request, *args, **kwargs)
                            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='507' class="post-context" id="post140515730382848">
                  
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>        except Exception as exc:</pre></li>
                  
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>            response = self.handle_exception(exc)</pre></li>
                  
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>        self.response = self.finalize_response(request, response, *args, **kwargs)</pre></li>
                  
                  <li onclick="toggle('pre140515730382848', 'post140515730382848')"><pre>        return self.response</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730382848">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>args</td>
                    <td class="code"><pre>()</pre></td>
                  </tr>
                
                  <tr>
                    <td>handler</td>
                    <td class="code"><pre>&lt;bound method CacheWebhookView.post of &lt;data_food_consortium.views.CacheWebhookView object at 0x7fcc5e31c910&gt;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>kwargs</td>
                    <td class="code"><pre>{}</pre></td>
                  </tr>
                
                  <tr>
                    <td>request</td>
                    <td class="code"><pre>&lt;rest_framework.request.Request: POST &#x27;/djangoldp-dfc/webhook/&#x27;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;data_food_consortium.views.CacheWebhookView object at 0x7fcc5e31c910&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/sibserver/data_food_consortium/views.py</code>, line 90, in post
          

          
            <div class="context" id="c140515730382976">
              
                <ol start="83" class="pre-context" id="pre140515730382976">
                
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>                    return Response(</pre></li>
                
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>                        {</pre></li>
                
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>                            &quot;error&quot;: &quot;Objects should be serialised with only @id and @type&quot;</pre></li>
                
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>                        },</pre></li>
                
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>                        status=400,</pre></li>
                
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>                    )</pre></li>
                
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre></pre></li>
                
                </ol>
              
              <ol start="90" class="context-line">
                <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>        self.process(request, data)
            ^^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='91' class="post-context" id="post140515730382976">
                  
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>        return Response({}, status=200)</pre></li>
                  
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>class EnterpriseImportView(BaseCSVImportView):</pre></li>
                  
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>    def get_form_class(self, *args, **kwargs):</pre></li>
                  
                  <li onclick="toggle('pre140515730382976', 'post140515730382976')"><pre>        return EnterpriseImportForm(*args, **kwargs)</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730382976">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>args</td>
                    <td class="code"><pre>()</pre></td>
                  </tr>
                
                  <tr>
                    <td>data</td>
                    <td class="code"><pre>{&#x27;enterpriseUrlid&#x27;: &#x27;http://test.host/api/dfc/enterprises&#x27;,
 &#x27;eventType&#x27;: &#x27;refresh&#x27;,
 &#x27;scope&#x27;: &#x27;ReadEnterprise&#x27;}</pre></td>
                  </tr>
                
                  <tr>
                    <td>kwargs</td>
                    <td class="code"><pre>{}</pre></td>
                  </tr>
                
                  <tr>
                    <td>request</td>
                    <td class="code"><pre>&lt;rest_framework.request.Request: POST &#x27;/djangoldp-dfc/webhook/&#x27;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;data_food_consortium.views.CacheWebhookView object at 0x7fcc5e31c910&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/sibserver/data_food_consortium/views.py</code>, line 46, in process
          

          
            <div class="context" id="c140515730381760">
              
                <ol start="39" class="pre-context" id="pre140515730381760">
                
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>    def process(self, request, data):</pre></li>
                
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>        if data[&quot;eventType&quot;] == WebhookEventType.UPDATE:</pre></li>
                
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>            # Parse and import the graph.</pre></li>
                
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>            # TODO: trigger optional behaviour in the parser to fail loudly.</pre></li>
                
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>            ProxyRefreshParser(data[&quot;@id&quot;]).parse(data)</pre></li>
                
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>        elif data[&quot;eventType&quot;] == WebhookEventType.REFRESH:</pre></li>
                
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>            host = urlparse(request.platform_urlid)</pre></li>
                
                </ol>
              
              <ol start="46" class="context-line">
                <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>            ResourceServerClient(f&quot;{host.scheme}://{host.netloc}/&quot;).request_scope(
                ^</pre> <span>…</span></li>
              </ol>
              
                <ol start='47' class="post-context" id="post140515730381760">
                  
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>                data[&quot;scope&quot;]</pre></li>
                  
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>            )</pre></li>
                  
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>        elif data[&quot;eventType&quot;] == WebhookEventType.REVOKE:</pre></li>
                  
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>            for obj in data[&quot;objects&quot;]:</pre></li>
                  
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>                Model.get_subclass_with_rdf_type(obj[&quot;@type&quot;]).objects.filter(</pre></li>
                  
                  <li onclick="toggle('pre140515730381760', 'post140515730381760')"><pre>                    proxy_of=obj[&quot;@id&quot;]</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730381760">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>data</td>
                    <td class="code"><pre>{&#x27;enterpriseUrlid&#x27;: &#x27;http://test.host/api/dfc/enterprises&#x27;,
 &#x27;eventType&#x27;: &#x27;refresh&#x27;,
 &#x27;scope&#x27;: &#x27;ReadEnterprise&#x27;}</pre></td>
                  </tr>
                
                  <tr>
                    <td>host</td>
                    <td class="code"><pre>ParseResult(scheme=&#x27;https&#x27;, netloc=&#x27;staging.openfoodnetwork.org.uk&#x27;, path=&#x27;/&#x27;, params=&#x27;&#x27;, query=&#x27;&#x27;, fragment=&#x27;&#x27;)</pre></td>
                  </tr>
                
                  <tr>
                    <td>request</td>
                    <td class="code"><pre>&lt;rest_framework.request.Request: POST &#x27;/djangoldp-dfc/webhook/&#x27;&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;data_food_consortium.views.CacheWebhookView object at 0x7fcc5e31c910&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/sibserver/data_food_consortium/proxy/resource.py</code>, line 322, in request_scope
          

          
            <div class="context" id="c140515730383616">
              
                <ol start="315" class="pre-context" id="pre140515730383616">
                
                  <li onclick="toggle('pre140515730383616', 'post140515730383616')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730383616', 'post140515730383616')"><pre>        :raises KeycloakAuthenticationException: if authentication with Keycloak is unsuccessful</pre></li>
                
                  <li onclick="toggle('pre140515730383616', 'post140515730383616')"><pre>        :raises RequestException: if dataserver request is unsuccessful</pre></li>
                
                  <li onclick="toggle('pre140515730383616', 'post140515730383616')"><pre>        &quot;&quot;&quot;</pre></li>
                
                  <li onclick="toggle('pre140515730383616', 'post140515730383616')"><pre>        # Each scope has an associated endpoint.</pre></li>
                
                  <li onclick="toggle('pre140515730383616', 'post140515730383616')"><pre>        endpoint = f&quot;{self.dataserver_url}{self.scope_config[scope]}&quot;</pre></li>
                
                  <li onclick="toggle('pre140515730383616', 'post140515730383616')"><pre>        parser = ProxyRefreshParser(endpoint)</pre></li>
                
                </ol>
              
              <ol start="322" class="context-line">
                <li onclick="toggle('pre140515730383616', 'post140515730383616')"><pre>        self._request_and_process_scope_at_endpoint(parser, scope, endpoint)
             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='323' class="post-context" id="post140515730383616">
                  
                  <li onclick="toggle('pre140515730383616', 'post140515730383616')"><pre>        parser.clean_up()</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730383616">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>endpoint</td>
                    <td class="code"><pre>&#x27;<HIDDEN-OPENID_APP_ID>enterprises/&#x27;</pre></td>
                  </tr>
                
                  <tr>
                    <td>parser</td>
                    <td class="code"><pre>&lt;data_food_consortium.proxy.resource.ProxyRefreshParser object at 0x7fcc5e32c990&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>scope</td>
                    <td class="code"><pre>&#x27;ReadEnterprise&#x27;</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;data_food_consortium.proxy.resource.ResourceServerClient object at 0x7fcc5e31df90&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/sibserver/data_food_consortium/proxy/resource.py</code>, line 303, in _request_and_process_scope_at_endpoint
          

          
            <div class="context" id="c140515730449664">
              
                <ol start="296" class="pre-context" id="pre140515730449664">
                
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        Requests an access token from Keycloak for a given scope,</pre></li>
                
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        and then recursively requests from the dataserver the associated endpoint,</pre></li>
                
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        scraping all available data until complete.</pre></li>
                
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        &quot;&quot;&quot;</pre></li>
                
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        headers = self._get_auth_headers_with_token_for_scope(scope)</pre></li>
                
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        response = requests.get(endpoint, headers=headers)</pre></li>
                
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        response.raise_for_status()</pre></li>
                
                </ol>
              
              <ol start="303" class="context-line">
                <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        data = response.json()
                    ^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='304' class="post-context" id="post140515730449664">
                  
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        # Parse the returned graph, resolve and import to the relevant models.</pre></li>
                  
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        parser.parse(data)</pre></li>
                  
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        # If there is more data, continue.</pre></li>
                  
                  <li onclick="toggle('pre140515730449664', 'post140515730449664')"><pre>        if &quot;next&quot; in data and data[&quot;next&quot;] is not None:</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730449664">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>endpoint</td>
                    <td class="code"><pre>&#x27;<HIDDEN-OPENID_APP_ID>enterprises/&#x27;</pre></td>
                  </tr>
                
                  <tr>
                    <td>headers</td>
                    <td class="code"><pre>{&#x27;Authorization&#x27;: &#x27;Bearer &#x27;
                  &#x27;eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJRRlJES1daQ2hzMllQYnRqYl9yQUtwQzNzMFo0T2FCMEtFQ056NnlxWHQ0In0.eyJleHAiOjE3NTg2ODcyMzYsImlhdCI6MTc1ODY4NjkzNiwianRpIjoiOTU5MmY1MjItMzllYS00ZmE2LThiYzMtZDVhZDZkM2M0YjRiIiwiaXNzIjoiaHR0cHM6Ly9rYy5jcWNtLnN0YXJ0aW5ibG94LmNvbS9yZWFsbXMvc3RhcnRpbmJsb3giLCJhdWQiOiJhY2NvdW50Iiwic3ViIjoiNWZlM2MyNmMtMjczNi00OGE0LWI2Y2YtYTllM2JjZmNkZjAwIiwidHlwIjoiQmVhcmVyIiwiYXpwIjoiaHR0cHM6Ly9hcGkucHJveHktZGV2LmNxY20uc3RhcnRpbmJsb3guY29tL3Byb2ZpbGUiLCJyZWFsbV9hY2Nlc3MiOnsicm9sZXMiOlsib2ZmbGluZV9hY2Nlc3MiLCJ1bWFfYXV0aG9yaXphdGlvbiIsImRlZmF1bHQtcm9sZXMtc3RhcnRpbmJsb3giXX0sInJlc291cmNlX2FjY2VzcyI6eyJhY2NvdW50Ijp7InJvbGVzIjpbIm1hbmFnZS1hY2NvdW50IiwibWFuYWdlLWFjY291bnQtbGlua3MiLCJ2aWV3LXByb2ZpbGUiXX19LCJzY29wZSI6IlJlYWRFbnRlcnByaXNlIiwiY2xpZW50SG9zdCI6IjE3Mi4xOC4wLjEiLCJjbGllbnRBZGRyZXNzIjoiMTcyLjE4LjAuMSIsImNsaWVudF9pZCI6Imh0dHBzOi8vYXBpLnByb3h5LWRldi5jcWNtLnN0YXJ0aW5ibG94LmNvbS9wcm9maWxlIn0.E58KWdWB19UvDUTzEypOFrqUG36crBD5nfCffUvpqwhapkzeSbGD0e1vobL7hqigXfQgkeR5eHERzDbjVwiMUlS7vxTRJym_ZesKXRasyJjxg7HmVqZAziFvjlzuv8ggtGjuLYcbCwgqEn_YMqwaL6VUatU-zN-0UZ6wOkhdyFtgqA3P-s3g6zmOs0K8ceTHA8R_aDYNJX0rfMTk2Gz1gF3I_FxcPVgwFQW3Dj1Xur8vYmc9_CnifvaVw4v35fWpCn4rXjMMznEoWpuQfz84fvAE5uSLMEWXmmYgM5IqiKcceCu7qJiJkEoCrsOsIU01u7DeQzW8pRvuVnIA8SRfcQ&#x27;}</pre></td>
                  </tr>
                
                  <tr>
                    <td>parser</td>
                    <td class="code"><pre>&lt;data_food_consortium.proxy.resource.ProxyRefreshParser object at 0x7fcc5e32c990&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>response</td>
                    <td class="code"><pre>&lt;Response [200]&gt;</pre></td>
                  </tr>
                
                  <tr>
                    <td>scope</td>
                    <td class="code"><pre>&#x27;ReadEnterprise&#x27;</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;data_food_consortium.proxy.resource.ResourceServerClient object at 0x7fcc5e31df90&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
        
        <li class="frame user">
          
            <code class="fname">/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/requests/models.py</code>, line 975, in json
          

          
            <div class="context" id="c140515730446336">
              
                <ol start="968" class="pre-context" id="pre140515730446336">
                
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>                    raise RequestsJSONDecodeError(e.msg, e.doc, e.pos)</pre></li>
                
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre></pre></li>
                
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>        try:</pre></li>
                
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>            return complexjson.loads(self.text, **kwargs)</pre></li>
                
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>        except JSONDecodeError as e:</pre></li>
                
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>            # Catch JSON-related errors and raise as requests.JSONDecodeError</pre></li>
                
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>            # This aliases json.JSONDecodeError and simplejson.JSONDecodeError</pre></li>
                
                </ol>
              
              <ol start="975" class="context-line">
                <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>            raise RequestsJSONDecodeError(e.msg, e.doc, e.pos)
                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^</pre> <span>…</span></li>
              </ol>
              
                <ol start='976' class="post-context" id="post140515730446336">
                  
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>    @property</pre></li>
                  
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>    def links(self):</pre></li>
                  
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>        &quot;&quot;&quot;Returns the parsed header links of the response, if any.&quot;&quot;&quot;</pre></li>
                  
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre></pre></li>
                  
                  <li onclick="toggle('pre140515730446336', 'post140515730446336')"><pre>        header = self.headers.get(&quot;link&quot;)</pre></li>
                  
              </ol>
              
            </div>
          

          
            
              <details>
                <summary class="commands">Local vars</summary>
            
            <table class="vars" id="v140515730446336">
              <thead>
                <tr>
                  <th>Variable</th>
                  <th>Value</th>
                </tr>
              </thead>
              <tbody>
                
                  <tr>
                    <td>kwargs</td>
                    <td class="code"><pre>{}</pre></td>
                  </tr>
                
                  <tr>
                    <td>self</td>
                    <td class="code"><pre>&lt;Response [200]&gt;</pre></td>
                  </tr>
                
              </tbody>
            </table>
            </details>
          
        </li>
      
    </ul>
  </div>

  <form action="https://dpaste.com/" name="pasteform" id="pasteform" method="post">
  <div id="pastebinTraceback" class="pastebin">
    <input type="hidden" name="language" value="PythonConsole">
    <input type="hidden" name="title"
      value="JSONDecodeError at /djangoldp-dfc/webhook/">
    <input type="hidden" name="source" value="Django Dpaste Agent">
    <input type="hidden" name="poster" value="Django">
    <textarea name="content" id="traceback_area" cols="140" rows="25">
Environment:


Request Method: POST
Request URL: https://api.proxy-dev.cqcm.startinblox.com/djangoldp-dfc/webhook/

Django Version: 4.2.20
Python Version: 3.11.13
Installed Applications:
[&#x27;djangoldp_account&#x27;,
 &#x27;data_food_consortium&#x27;,
 &#x27;djangoldp_csv&#x27;,
 &#x27;oidc_provider&#x27;,
 &#x27;django.contrib.admin&#x27;,
 &#x27;django.contrib.auth&#x27;,
 &#x27;django.contrib.contenttypes&#x27;,
 &#x27;django.contrib.sessions&#x27;,
 &#x27;django.contrib.messages&#x27;,
 &#x27;django.contrib.staticfiles&#x27;,
 &#x27;djangoldp&#x27;,
 &#x27;guardian&#x27;]
Installed Middleware:
&#x27;&#x27;



Traceback (most recent call last):
  File "/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/requests/models.py", line 971, in json
    return complexjson.loads(self.text, **kwargs)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/alwaysdata/python/3.11/lib/python3.11/json/__init__.py", line 346, in loads
    return _default_decoder.decode(s)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/alwaysdata/python/3.11/lib/python3.11/json/decoder.py", line 337, in decode
    obj, end = self.raw_decode(s, idx=_w(s, 0).end())
               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/usr/alwaysdata/python/3.11/lib/python3.11/json/decoder.py", line 355, in raw_decode
    raise JSONDecodeError(&quot;Expecting value&quot;, s, err.value) from None
    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

During handling of the above exception (Expecting value: line 1 column 1 (char 0)), another exception occurred:
  File "/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/django/core/handlers/exception.py", line 55, in inner
    response = get_response(request)
               ^^^^^^^^^^^^^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/django/core/handlers/base.py", line 197, in _get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/django/views/decorators/csrf.py", line 56, in wrapper_view
    return view_func(*args, **kwargs)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/django/views/generic/base.py", line 104, in view
    return self.dispatch(request, *args, **kwargs)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/rest_framework/views.py", line 509, in dispatch
    response = self.handle_exception(exc)
               ^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/rest_framework/views.py", line 469, in handle_exception
    self.raise_uncaught_exception(exc)
    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/rest_framework/views.py", line 480, in raise_uncaught_exception
    raise exc
    ^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/rest_framework/views.py", line 506, in dispatch
    response = handler(request, *args, **kwargs)
               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/sibserver/data_food_consortium/views.py", line 90, in post
    self.process(request, data)
    ^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/sibserver/data_food_consortium/views.py", line 46, in process
    ResourceServerClient(f&quot;{host.scheme}://{host.netloc}/&quot;).request_scope(
    ^
  File "/home/cqcm-proxy-dev/startinblox/sibserver/data_food_consortium/proxy/resource.py", line 322, in request_scope
    self._request_and_process_scope_at_endpoint(parser, scope, endpoint)
    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/sibserver/data_food_consortium/proxy/resource.py", line 303, in _request_and_process_scope_at_endpoint
    data = response.json()
           ^^^^^^^^^^^^^^^
  File "/home/cqcm-proxy-dev/startinblox/venv/lib/python3.11/site-packages/requests/models.py", line 975, in json
    raise RequestsJSONDecodeError(e.msg, e.doc, e.pos)
    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Exception Type: JSONDecodeError at /djangoldp-dfc/webhook/
Exception Value: Expecting value: line 1 column 1 (char 0)
</textarea>
  <br><br>
  <input type="submit" value="Share this traceback on a public website">
  </div>
</form>

</div>


<div id="requestinfo">
  <h2>Request information</h2>


  
    <h3 id="user-info">USER</h3>
    <p>AnonymousUser</p>
  

  <h3 id="get-info">GET</h3>
  
    <p>No GET data</p>
  

  <h3 id="post-info">POST</h3>
  
    <p>No POST data</p>
  

  <h3 id="files-info">FILES</h3>
  
    <p>No FILES data</p>
  

  <h3 id="cookie-info">COOKIES</h3>
  
    <p>No cookie data</p>
  

  <h3 id="meta-info">META</h3>
  <table class="req">
    <thead>
      <tr>
        <th>Variable</th>
        <th>Value</th>
      </tr>
    </thead>
    <tbody>
      
        <tr>
          <td>CONTENT_LENGTH</td>
          <td class="code"><pre>&#x27;105&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>CONTENT_TYPE</td>
          <td class="code"><pre>&#x27;application/json&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>HTTP_ACCEPT</td>
          <td class="code"><pre>&#x27;*/*&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>HTTP_ACCEPT_ENCODING</td>
          <td class="code"><pre>&#x27;gzip;q=1.0,deflate;q=0.6,identity;q=0.3&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>HTTP_AUTHORIZATION</td>
          <td class="code"><pre>(&#x27;Bearer &#x27;
 &#x27;eyJhbGciOiJSUzI1NiIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJRRlJES1daQ2hzMllQYnRqYl9yQUtwQzNzMFo0T2FCMEtFQ056NnlxWHQ0In0.eyJleHAiOjE3NTg2ODcyMzMsImlhdCI6MTc1ODY4NjkzMywianRpIjoiZTdjMTlkMDQtODhhNC00NzcxLWI4NDctMTZhZmNiMjIwNjM0IiwiaXNzIjoiaHR0cHM6Ly9rYy5jcWNtLnN0YXJ0aW5ibG94LmNvbS9yZWFsbXMvc3RhcnRpbmJsb3giLCJhdWQiOiJhY2NvdW50Iiwic3ViIjoiMTg4Yjg5MjUtYmZkOC00MTliLThlNTUtOWZiNTZiODAwNjQ5IiwidHlwIjoiQmVhcmVyIiwiYXpwIjoiaHR0cHM6Ly9zdGFnaW5nLm9wZW5mb29kbmV0d29yay5vcmcudWsvIiwiYWNyIjoiMSIsImFsbG93ZWQtb3JpZ2lucyI6WyJodHRwczovL3N0YWdpbmcub3BlbmZvb2RuZXR3b3JrLm9yZy51ay8iXSwicmVhbG1fYWNjZXNzIjp7InJvbGVzIjpbIm9mZmxpbmVfYWNjZXNzIiwidW1hX2F1dGhvcml6YXRpb24iLCJkZWZhdWx0LXJvbGVzLXN0YXJ0aW5ibG94Il19LCJyZXNvdXJjZV9hY2Nlc3MiOnsiYWNjb3VudCI6eyJyb2xlcyI6WyJtYW5hZ2UtYWNjb3VudCIsIm1hbmFnZS1hY2NvdW50LWxpbmtzIiwidmlldy1wcm9maWxlIl19LCJodHRwczovL3N0YWdpbmcub3BlbmZvb2RuZXR3b3JrLm9yZy51ay8iOnsicm9sZXMiOlsidW1hX3Byb3RlY3Rpb24iXX19LCJzY29wZSI6IldyaXRlRW50ZXJwcmlzZSBwcm9maWxlIGVtYWlsIiwiZW1haWxfdmVyaWZpZWQiOmZhbHNlLCJjbGllbnRIb3N0IjoiMTcyLjE4LjAuMSIsInByZWZlcnJlZF91c2VybmFtZSI6InNlcnZpY2UtYWNjb3VudC1odHRwczovL3N0YWdpbmcub3BlbmZvb2RuZXR3b3JrLm9yZy51ay8iLCJjbGllbnRBZGRyZXNzIjoiMTcyLjE4LjAuMSIsImNsaWVudF9pZCI6Imh0dHBzOi8vc3RhZ2luZy5vcGVuZm9vZG5ldHdvcmsub3JnLnVrLyJ9.CGrATYp9O2BoLjR5iEHFYt4Q6paHKAKin4QJN-pgmBqymelnXOj_VfjvRN8PMyO0sK7543B_I7KfdwK9oekhHNFHzJNH1vyRFCj0M9O729px5a0hPirs7krN6tDfnrWKX3jPk09zAkfKRhHPFvv5MLQvshsH3YAK6T4XPmUfnIDCJAUbQl7cocpz1r4pSNdy4xM6oBNnzssNtarn7NXBeLZNKabrbqPy1GwX5IDm71bl2_z4mgGehUwPHdZ3W0Yb63O-blwWXwSIWh3eG_QN4d9oM11B7F2P8D7b6zx2QEwyyY3so4dxU3InyyC7-GT7Y4mMn15tXh7r_z7DRlVuHA&#x27;)</pre></td>
        </tr>
      
        <tr>
          <td>HTTP_HOST</td>
          <td class="code"><pre>&#x27;api.proxy-dev.cqcm.startinblox.com&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>HTTP_USER_AGENT</td>
          <td class="code"><pre>&#x27;Faraday v2.9.0&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>HTTP_VIA</td>
          <td class="code"><pre>&#x27;1.1 alproxy&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>HTTP_X_FORWARDED_PROTO</td>
          <td class="code"><pre>&#x27;https&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>HTTP_X_REAL_IP</td>
          <td class="code"><pre>&#x27;182.239.194.118&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>PATH_INFO</td>
          <td class="code"><pre>&#x27;/djangoldp-dfc/webhook/&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>QUERY_STRING</td>
          <td class="code"><pre>&#x27;&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>REMOTE_ADDR</td>
          <td class="code"><pre>&#x27;182.239.194.118&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>REQUEST_METHOD</td>
          <td class="code"><pre>&#x27;POST&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>REQUEST_URI</td>
          <td class="code"><pre>&#x27;/djangoldp-dfc/webhook/&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>SCRIPT_NAME</td>
          <td class="code"><pre>&#x27;&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>SERVER_NAME</td>
          <td class="code"><pre>&#x27;astral&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>SERVER_PORT</td>
          <td class="code"><pre>&#x27;8100&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>SERVER_PROTOCOL</td>
          <td class="code"><pre>&#x27;HTTP/1.1&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>uwsgi.node</td>
          <td class="code"><pre>b&#x27;astral&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>uwsgi.version</td>
          <td class="code"><pre>b&#x27;2.0.28&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>wsgi.errors</td>
          <td class="code"><pre>&lt;_io.TextIOWrapper name=2 mode=&#x27;w&#x27; encoding=&#x27;UTF-8&#x27;&gt;</pre></td>
        </tr>
      
        <tr>
          <td>wsgi.input</td>
          <td class="code"><pre>&lt;uwsgi._Input object at 0x7fcc5ec75230&gt;</pre></td>
        </tr>
      
        <tr>
          <td>wsgi.multiprocess</td>
          <td class="code"><pre>True</pre></td>
        </tr>
      
        <tr>
          <td>wsgi.multithread</td>
          <td class="code"><pre>False</pre></td>
        </tr>
      
        <tr>
          <td>wsgi.run_once</td>
          <td class="code"><pre>False</pre></td>
        </tr>
      
        <tr>
          <td>wsgi.url_scheme</td>
          <td class="code"><pre>&#x27;https&#x27;</pre></td>
        </tr>
      
        <tr>
          <td>wsgi.version</td>
          <td class="code"><pre>(1, 0)</pre></td>
        </tr>
      
    </tbody>
  </table>


  <h3 id="settings-info">Settings</h3>
  <h4>Using settings module <code></code></h4>
  <table class="req">
    <thead>
      <tr>
        <th>Setting</th>
        <th>Value</th>
      </tr>
    </thead>
    <tbody>
      
        <tr>
          <td>DJANGOLDP_PACKAGES</td>
          <td class="code"><pre>[&#x27;djangoldp_account&#x27;, &#x27;data_food_consortium&#x27;, &#x27;djangoldp_csv&#x27;]</pre></td>
        </tr>
      
        <tr>
          <td>INSTALLED_APPS</td>
          <td class="code"><pre>[&#x27;djangoldp_account&#x27;,
 &#x27;data_food_consortium&#x27;,
 &#x27;djangoldp_csv&#x27;,
 &#x27;oidc_provider&#x27;,
 &#x27;django.contrib.admin&#x27;,
 &#x27;django.contrib.auth&#x27;,
 &#x27;django.contrib.contenttypes&#x27;,
 &#x27;django.contrib.sessions&#x27;,
 &#x27;django.contrib.messages&#x27;,
 &#x27;django.contrib.staticfiles&#x27;,
 &#x27;djangoldp&#x27;,
 &#x27;guardian&#x27;]</pre></td>
        </tr>
      
    </tbody>
  </table>

</div>

  <div id="explanation">
    <p>
      You’re seeing this error because you have <code>DEBUG = True</code> in your
      Django settings file. Change that to <code>False</code>, and Django will
      display a standard page generated by the handler for this status code.
    </p>
  </div>

</body>
</html>

|
|
recorded_at: Wed, 24 Sep 2025 04:08:57 GMT
|
|
recorded_with: VCR 6.2.0
|