{
  "instance_id": "django__django-12915",
  "repo": "django/django",
  "created_at": "2020-05-14T23:30:01Z",
  "problem_statement": "Add get_response_async for ASGIStaticFilesHandler\nDescription\n\t\nIt looks like the StaticFilesHandlerMixin is missing the the async response function.\nWithout this, when trying to use the ASGIStaticFilesHandler, this is the traceback:\nException inside application: 'NoneType' object is not callable\nTraceback (most recent call last):\n File \".../lib/python3.7/site-packages/daphne/cli.py\", line 30, in asgi\n\tawait self.app(scope, receive, send)\n File \".../src/django/django/contrib/staticfiles/handlers.py\", line 86, in __call__\n\treturn await super().__call__(scope, receive, send)\n File \".../src/django/django/core/handlers/asgi.py\", line 161, in __call__\n\tresponse = await self.get_response_async(request)\n File \".../src/django/django/core/handlers/base.py\", line 148, in get_response_async\n\tresponse = await self._middleware_chain(request)\nTypeError: 'NoneType' object is not callable\n",
  "patch": "diff --git a/django/contrib/staticfiles/handlers.py b/django/contrib/staticfiles/handlers.py\n--- a/django/contrib/staticfiles/handlers.py\n+++ b/django/contrib/staticfiles/handlers.py\n@@ -1,6 +1,8 @@\n from urllib.parse import urlparse\n from urllib.request import url2pathname\n \n+from asgiref.sync import sync_to_async\n+\n from django.conf import settings\n from django.contrib.staticfiles import utils\n from django.contrib.staticfiles.views import serve\n@@ -52,6 +54,12 @@ def get_response(self, request):\n         except Http404 as e:\n             return response_for_exception(request, e)\n \n+    async def get_response_async(self, request):\n+        try:\n+            return await sync_to_async(self.serve)(request)\n+        except Http404 as e:\n+            return await sync_to_async(response_for_exception)(request, e)\n+\n \n class StaticFilesHandler(StaticFilesHandlerMixin, WSGIHandler):\n     \"\"\"\n",
  "similar_bug_items": [
    {
      "pr_number": 11886,
      "pr_title": "Fixed #30405 -- Fixed source code mismatch crash in ExceptionReporter. ",
      "pr_body": "[ticket 30405](https://code.djangoproject.com/ticket/30405)",
      "issue_id": 30405,
      "issue_title": "IndexError in _get_lines_from_file when module does not match file contents (via loader)",
      "issue_body": "self = <django.views.debug.ExceptionReporter object at 0x7f2a7908ac18>\nfilename = '…/project/.venv/lib/python3.7/site-packages/pdb.py'\nlineno = 230\ncontext_lines = 7\nloader = <_frozen_importlib_external.SourceFileLoader object at 0x7f2a73609278>\nmodule_name = 'pdb'\n\n[23]   …/Vcs/django/django/core/handlers/exception.py(90)response_for_exception()\n-> response = handle_uncaught_exception(request, get_resolver(get_urlconf()), sys.exc_info())\n[24]   …/Vcs/django/django/core/handlers/exception.py(125)handle_uncaught_exception()\n-> return debug.technical_500_response(request, *exc_info)\n[25]   …/Vcs/django/django/views/debug.py(94)technical_500_response()\n-> html = reporter.get_traceback_html()\n[26]   …/Vcs/django/django/views/debug.py(333)get_traceback_html()\n-> c = Context(self.get_traceback_data(), use_l10n=False)\n[27]   …/Vcs/django/django/views/debug.py(264)get_traceback_data()\n-> frames = self.get_traceback_frames()\n[28]   …/Vcs/django/django/views/debug.py(427)get_traceback_frames()\n-> filename, lineno, 7, loader, module_name,\n\n 385             try:\n 386                 context_line = source[lineno]\n 387             except:\n 388                 __import__('pdb').set_trace()\n 389  ->         post_context = source[lineno + 1:upper_bound]\n 390\n 391             return lower_bound, pre_context, context_line, post_context\n(Pdb++) source\n['# this file is needed to hijack pdb without eggs', 'import os.path', \"pdb_path = os.path.join(os.path.dirname(os.path.dirname(__file__)), 'pdb.py')\", 'with open(pdb_path) as f:', \"    exec(compile(f.read(), pdb_path, 'exec'))\"]\nIt uses the loader (\n​\nhttps://github.com/django/django/blob/47885278c669dd7a13a4c3ff7e58e1cbe88af385/django/views/debug.py#L351\n), which picks up the\npth\n, and then the contents does not match the expected line number.\nI think it should maybe always use the given filename?!",
      "issue_closed_at": "2019-11-12T04:53:04",
      "base_commit": "6e2f05b2e33a6c80c7a411ce76af7b5a08acb835",
      "changes": [
        {
          "file": "django/views/debug.py",
          "type": "function",
          "name": "get_traceback_text",
          "class_name": "ExceptionReporter",
          "code": "def get_traceback_text(self):\n        \"\"\"Return plain text version of debug 500 HTTP error page.\"\"\"\n        with Path(CURRENT_DIR, 'templates', 'technical_500.txt').open(encoding='utf-8') as fh:\n            t = DEBUG_ENGINE.from_string(fh.read())\n        c = Context(self.get_traceback_data(), autoescape=False, use_l10n=False)\n        return t.render(c)"
        },
        {
          "file": "django/views/debug.py",
          "type": "function",
          "name": "_get_lines_from_file",
          "class_name": "ExceptionReporter",
          "code": "def _get_lines_from_file(self, filename, lineno, context_lines, loader=None, module_name=None):\n        \"\"\"\n        Return context_lines before and after lineno from file.\n        Return (pre_context_lineno, pre_context, context_line, post_context).\n        \"\"\"\n        source = None\n        if hasattr(loader, 'get_source'):\n            try:\n                source = loader.get_source(module_name)\n            except ImportError:\n                pass\n            if source is not None:\n                source = source.splitlines()\n        if source is None:\n            try:\n                with open(filename, 'rb') as fp:\n                    source = fp.read().splitlines()\n            except OSError:\n                pass\n        if source is None:\n            return None, [], None, []\n\n        # If we just read the source from a file, or if the loader did not\n        # apply tokenize.detect_encoding to decode the source into a\n        # string, then we should do that ourselves.\n        if isinstance(source[0], bytes):\n            encoding = 'ascii'\n            for line in source[:2]:\n                # File coding may be specified. Match pattern from PEP-263\n                # (https://www.python.org/dev/peps/pep-0263/)\n                match = re.search(br'coding[:=]\\s*([-\\w.]+)', line)\n                if match:\n                    encoding = match.group(1).decode('ascii')\n                    break\n            source = [str(sline, encoding, 'replace') for sline in source]\n\n        lower_bound = max(0, lineno - context_lines)\n        upper_bound = lineno + context_lines\n\n        pre_context = source[lower_bound:lineno]\n        context_line = source[lineno]\n        post_context = source[lineno + 1:upper_bound]\n\n        return lower_bound, pre_context, context_line, post_context"
        },
        {
          "file": "django/views/debug.py",
          "type": "function",
          "name": "_get_lines_from_file",
          "class_name": "ExceptionReporter",
          "code": "def _get_lines_from_file(self, filename, lineno, context_lines, loader=None, module_name=None):\n        \"\"\"\n        Return context_lines before and after lineno from file.\n        Return (pre_context_lineno, pre_context, context_line, post_context).\n        \"\"\"\n        source = None\n        if hasattr(loader, 'get_source'):\n            try:\n                source = loader.get_source(module_name)\n            except ImportError:\n                pass\n            if source is not None:\n                source = source.splitlines()\n        if source is None:\n            try:\n                with open(filename, 'rb') as fp:\n                    source = fp.read().splitlines()\n            except OSError:\n                pass\n        if source is None:\n            return None, [], None, []\n\n        # If we just read the source from a file, or if the loader did not\n        # apply tokenize.detect_encoding to decode the source into a\n        # string, then we should do that ourselves.\n        if isinstance(source[0], bytes):\n            encoding = 'ascii'\n            for line in source[:2]:\n                # File coding may be specified. Match pattern from PEP-263\n                # (https://www.python.org/dev/peps/pep-0263/)\n                match = re.search(br'coding[:=]\\s*([-\\w.]+)', line)\n                if match:\n                    encoding = match.group(1).decode('ascii')\n                    break\n            source = [str(sline, encoding, 'replace') for sline in source]\n\n        lower_bound = max(0, lineno - context_lines)\n        upper_bound = lineno + context_lines\n\n        pre_context = source[lower_bound:lineno]\n        context_line = source[lineno]\n        post_context = source[lineno + 1:upper_bound]\n\n        return lower_bound, pre_context, context_line, post_context"
        }
      ]
    },
    {
      "pr_number": 9112,
      "pr_title": "Fixed #27846 -- clear all cached reverse relationships on refresh_from_db()",
      "pr_body": "https://code.djangoproject.com/ticket/27846",
      "issue_id": 27846,
      "issue_title": "refresh_from_db() doesn't clear reverse OneToOneFields",
      "issue_body": "Sorry for the poor summary, it is difficult to explain in words. I have a project to demo this bug attached to this ticket, but I will try to explain the bug anyway in steps and the setup.\nSetup:\n2 models (A and B)\nB has a OneToOne to A\nBoth A and B have a field (ie TextField)\nSetup either a signal or override save() for A to update B's TextField to equal that of A's on save() or post_save for signals\nSteps:\nCreate instance of A\nGet another copy of the instance of A via A.objects.get()\nCreate instance of B using the copy of the instance of A\nDo refresh_from_db() on original instance of A\nTry to access B from A\nThe project I have provided is a slim version of this problem that demonstrates it with signals, overriden save(), and basic set and save inside the test. The basic set and save works, but the other two fail when using the above steps. Run the test suite to see.",
      "issue_closed_at": "2017-10-12T16:25:22",
      "base_commit": "df0aebc893973c78d7d2cda712ba4133dbe29b6e",
      "changes": [
        {
          "file": "django/db/models/base.py",
          "type": "function",
          "name": "refresh_from_db",
          "class_name": "Model",
          "code": "def refresh_from_db(self, using=None, fields=None):\n        \"\"\"\n        Reload field values from the database.\n\n        By default, the reloading happens from the database this instance was\n        loaded from, or by the read router if this instance wasn't loaded from\n        any database. The using parameter will override the default.\n\n        Fields can be used to specify which fields to reload. The fields\n        should be an iterable of field attnames. If fields is None, then\n        all non-deferred fields are reloaded.\n\n        When accessing deferred fields of an instance, the deferred loading\n        of the field will call this method.\n        \"\"\"\n        if fields is not None:\n            if len(fields) == 0:\n                return\n            if any(LOOKUP_SEP in f for f in fields):\n                raise ValueError(\n                    'Found \"%s\" in fields argument. Relations and transforms '\n                    'are not allowed in fields.' % LOOKUP_SEP)\n\n        db = using if using is not None else self._state.db\n        db_instance_qs = self.__class__._default_manager.using(db).filter(pk=self.pk)\n\n        # Use provided fields, if not set then reload all non-deferred fields.\n        deferred_fields = self.get_deferred_fields()\n        if fields is not None:\n            fields = list(fields)\n            db_instance_qs = db_instance_qs.only(*fields)\n        elif deferred_fields:\n            fields = [f.attname for f in self._meta.concrete_fields\n                      if f.attname not in deferred_fields]\n            db_instance_qs = db_instance_qs.only(*fields)\n\n        db_instance = db_instance_qs.get()\n        non_loaded_fields = db_instance.get_deferred_fields()\n        for field in self._meta.concrete_fields:\n            if field.attname in non_loaded_fields:\n                # This field wasn't refreshed - skip ahead.\n                continue\n            setattr(self, field.attname, getattr(db_instance, field.attname))\n            # Throw away stale foreign key references.\n            if field.is_relation and field.is_cached(self):\n                rel_instance = field.get_cached_value(self)\n                local_val = getattr(db_instance, field.attname)\n                related_val = None if rel_instance is None else getattr(rel_instance, field.target_field.attname)\n                if local_val != related_val or (local_val is None and related_val is None):\n                    field.delete_cached_value(self)\n        self._state.db = db_instance._state.db"
        }
      ]
    },
    {
      "pr_number": 652,
      "pr_title": "Fixed #19099 -- Split broken link emails out of common middleware.",
      "pr_body": "",
      "issue_id": 19099,
      "issue_title": "Broken link email sent on redirect by i18n_patterns",
      "issue_body": "With the following settings:\nMIDDLEWARE_CLASSES = {\n        # ...,\n        'django.middleware.locale.LocaleMiddleware',\n        'django.middleware.common.CommonMiddleware',\n        # ...,\n}\nSEND_BROKEN_LINKS_EMAIL = True\nwhen a redirect to an i18n'd URL occurs, a broken link email is sent.\nI'm attaching a failing test case.\nThis may be the expected behavior, but it's hard to diagnose. I started receiving broken link emails for '/', with various referrers and UAs. But going to that URL worked and didn't send an email, because there's no referrer when you go straight to the URL.\nThe solution might be documenting that\nCommonMiddleware\nmust come before\nLocaleMiddleware\n. The commit logs say that they used to be in that order, but that we swapped them because\nAPPEND_SLASH\ndidn't work (I haven't re-verified this yet). And then I started receiving the broken link emails.",
      "issue_closed_at": "2013-01-15T10:56:12",
      "base_commit": "83d0cc52141dbbd977da836fd7f77e0e735e2110",
      "changes": [
        {
          "file": "django/conf/global_settings.py",
          "type": "line",
          "name": "line 146",
          "code": "# Email address that error messages come from.\nSERVER_EMAIL = 'root@localhost'\n\n# Whether to send broken-link emails.\nSEND_BROKEN_LINK_EMAILS = False\n\n# Database connection info. If left empty, will default to the dummy backend."
        },
        {
          "file": "django/conf/global_settings.py",
          "type": "line",
          "name": "line 245",
          "code": "ADMIN_FOR = ()\n\n# List of compiled regular expression objects representing URLs that need not\n# be reported when SEND_BROKEN_LINK_EMAILS is True. Here are a few examples:\n#    import re\n#    IGNORABLE_404_URLS = (\n#        re.compile(r'^/apple-touch-icon.*\\.png$'),"
        },
        {
          "file": "django/middleware/common.py",
          "type": "line",
          "name": "line 1",
          "code": "import hashlib\nimport logging\nimport re\n\nfrom django.conf import settings\nfrom django import http\nfrom django.core.mail import mail_managers\nfrom django.utils.http import urlquote\nfrom django.utils import six\nfrom django.core import urlresolvers\n\n\nlogger = logging.getLogger('django.request')"
        },
        {
          "file": "django/middleware/common.py",
          "type": "function",
          "name": "process_request",
          "class_name": "CommonMiddleware",
          "code": "def process_request(self, request):\n        \"\"\"\n        Check for denied User-Agents and rewrite the URL based on\n        settings.APPEND_SLASH and settings.PREPEND_WWW\n        \"\"\"\n\n        # Check for denied User-Agents\n        if 'HTTP_USER_AGENT' in request.META:\n            for user_agent_regex in settings.DISALLOWED_USER_AGENTS:\n                if user_agent_regex.search(request.META['HTTP_USER_AGENT']):\n                    logger.warning('Forbidden (User agent): %s', request.path,\n                        extra={\n                            'status_code': 403,\n                            'request': request\n                        }\n                    )\n                    return http.HttpResponseForbidden('<h1>Forbidden</h1>')\n\n        # Check for a redirect based on settings.APPEND_SLASH\n        # and settings.PREPEND_WWW\n        host = request.get_host()\n        old_url = [host, request.path]\n        new_url = old_url[:]\n\n        if (settings.PREPEND_WWW and old_url[0] and\n                not old_url[0].startswith('www.')):\n            new_url[0] = 'www.' + old_url[0]\n\n        # Append a slash if APPEND_SLASH is set and the URL doesn't have a\n        # trailing slash and there is no pattern for the current path\n        if settings.APPEND_SLASH and (not old_url[1].endswith('/')):\n            urlconf = getattr(request, 'urlconf', None)\n            if (not urlresolvers.is_valid_path(request.path_info, urlconf) and\n                    urlresolvers.is_valid_path(\"%s/\" % request.path_info, urlconf)):\n                new_url[1] = new_url[1] + '/'\n                if settings.DEBUG and request.method == 'POST':\n                    raise RuntimeError((\"\"\n                    \"You called this URL via POST, but the URL doesn't end \"\n                    \"in a slash and you have APPEND_SLASH set. Django can't \"\n                    \"redirect to the slash URL while maintaining POST data. \"\n                    \"Change your form to point to %s%s (note the trailing \"\n                    \"slash), or set APPEND_SLASH=False in your Django \"\n                    \"settings.\") % (new_url[0], new_url[1]))\n\n        if new_url == old_url:\n            # No redirects required.\n            return\n        if new_url[0]:\n            newurl = \"%s://%s%s\" % (\n                request.is_secure() and 'https' or 'http',\n                new_url[0], urlquote(new_url[1]))\n        else:\n            newurl = urlquote(new_url[1])\n        if request.META.get('QUERY_STRING', ''):\n            if six.PY3:\n                newurl += '?' + request.META['QUERY_STRING']\n            else:\n                # `query_string` is a bytestring. Appending it to the unicode\n                # string `newurl` will fail if it isn't ASCII-only. This isn't\n                # allowed; only broken software generates such query strings.\n                # Better drop the invalid query string than crash (#15152).\n                try:\n                    newurl += '?' + request.META['QUERY_STRING'].decode()\n                except UnicodeDecodeError:\n                    pass\n        return http.HttpResponsePermanentRedirect(newurl)"
        },
        {
          "file": "django/middleware/common.py",
          "type": "function",
          "name": "process_response",
          "class_name": "CommonMiddleware",
          "code": "def process_response(self, request, response):\n        \"Send broken link emails and calculate the Etag, if needed.\"\n        if response.status_code == 404:\n            if settings.SEND_BROKEN_LINK_EMAILS and not settings.DEBUG:\n                # If the referrer was from an internal link or a non-search-engine site,\n                # send a note to the managers.\n                domain = request.get_host()\n                referer = request.META.get('HTTP_REFERER', None)\n                is_internal = _is_internal_request(domain, referer)\n                path = request.get_full_path()\n                if referer and not _is_ignorable_404(path) and (is_internal or '?' not in referer):\n                    ua = request.META.get('HTTP_USER_AGENT', '<none>')\n                    ip = request.META.get('REMOTE_ADDR', '<none>')\n                    mail_managers(\"Broken %slink on %s\" % ((is_internal and 'INTERNAL ' or ''), domain),\n                        \"Referrer: %s\\nRequested URL: %s\\nUser agent: %s\\nIP address: %s\\n\" \\\n                                  % (referer, request.get_full_path(), ua, ip),\n                                  fail_silently=True)\n                return response\n\n        # Use ETags, if requested.\n        if settings.USE_ETAGS:\n            if response.has_header('ETag'):\n                etag = response['ETag']\n            elif response.streaming:\n                etag = None\n            else:\n                etag = '\"%s\"' % hashlib.md5(response.content).hexdigest()\n            if etag is not None:\n                if (200 <= response.status_code < 300\n                    and request.META.get('HTTP_IF_NONE_MATCH') == etag):\n                    cookies = response.cookies\n                    response = http.HttpResponseNotModified()\n                    response.cookies = cookies\n                else:\n                    response['ETag'] = etag\n\n        return response"
        }
      ]
    },
    {
      "pr_number": 6540,
      "pr_title": "Fixed #26341 (again) -- Addressed multiple occurrences per line use case",
      "pr_body": "",
      "issue_id": 26341,
      "issue_title": "Weird comments in PO files (.html.py filenames)",
      "issue_body": "I just upgraded Django to 1.9.4 from 1.8.10, and sometimes, the filenames in PO files comments contain \".html.py\" extensions.\nThis is visible on django's main repository :\n​\nhttps://github.com/django/django/blob/ae4d932b1ac12651a7c57d89742c25483ee8c9f9/django/contrib/admin/locale/en/LC_MESSAGES/django.po#L282\n​\nhttps://github.com/django/django/blob/4323676ea5ab6994feb1385522665069d84f397b/django/contrib/admin/locale/en/LC_MESSAGES/django.po#L302\nIn this example, the \"contrib/admin/templates/admin/base_site.html\" file is now named \"contrib/admin/templates/admin/base_site.html.py\" (with a trailing \".py\") in the po file.\nThis seems to appear only on lines with a python file before the template html file.\nclaudep found that this could be the faulty commit :\n​\nhttps://github.com/django/django/commit/e75882332c",
      "issue_closed_at": "2016-04-30T05:07:43",
      "base_commit": "4e2ee8662753ca6a2619039b903f11c60709f398",
      "changes": [
        {
          "file": "django/core/management/commands/makemessages.py",
          "type": "function",
          "name": "postprocess_messages",
          "class_name": "BuildFile",
          "code": "def postprocess_messages(self, msgs):\n        \"\"\"\n        Postprocess messages generated by xgettext GNU gettext utility.\n\n        Transform paths as if these messages were generated from original\n        translatable files rather than from preprocessed versions.\n        \"\"\"\n        if not self.is_templatized:\n            return msgs\n\n        # Remove '.py' suffix\n        if os.name == 'nt':\n            # Preserve '.\\' prefix on Windows to respect gettext behavior\n            old_path = self.work_path\n            new_path = self.path\n        else:\n            old_path = self.work_path[2:]\n            new_path = self.path[2:]\n\n        return re.sub(\n            r'^(#: .*)(' + re.escape(old_path) + r')',\n            r'\\1' + new_path,\n            msgs,\n            flags=re.MULTILINE\n        )"
        }
      ]
    },
    {
      "pr_number": 12329,
      "pr_title": "Fixed #31162 -- Prevented error logs when using WKT strings in lookups.",
      "pr_body": "ticket-31162\r\n\r\nRegression in 6f44f714c92d2966dca390ebd3054e5fb0bb0c80.",
      "issue_id": 31162,
      "issue_title": "GIS error logging when using WKT string as input to filter() query.",
      "issue_body": "When executing a geometry lookup like\nmy_geo_model.objects.filter(my_geom__intersects=wkt_string)\n(i.e. using a WKT string as value)  django.contrib.gis emits the following errors:\n2020-01-13 10:16:07,145 - django.contrib.gis - ERROR - GDAL_ERROR 4: b'POLYGON ((1 1, 1 0, 0 0, 0 1, 1 1)): No such file or directory'\n2020-01-13 10:16:08,403 - django.contrib.gis - ERROR - GDAL_ERROR 10: b\"Pointer 'hObject' is NULL in 'GDALGetDescription'.\\n\"\nThe reason is that if passed a string, the string is first treated as a potential filename which GDAL tries to open and fails (\"no such file\"). Only then it is tried to open the string as WKT/GeoJSON etc. Older Django versions did not emit these errors. However, in commit 6f44f714c9 a check in django/contrib/gis/gdal/raster/source.py:69 whether the file exists was removed.\nSilencing all errors from django.contrib.gis is not really a feasable workaround, as it would mean silcencing interesting GIS errors too.\nAccording to\n​\nhttps://docs.djangoproject.com/en/2.2/ref/contrib/gis/db-api/#geometry-lookups\npassing WKT strings is allowed, but there's no mention of being able to pass a filename as parameter.\nIt's a bit unexpected that Django first tries to open a file before it checks whether the passed string is valid WKT/GeoJSON, and that using WKT results in error messages. Or am I misunderstanding the documentation and calling the API wrongly?\nRelevant parts of example source:\nmodels.py:\n\nclass Area(models.Model):\n    area = models.PolygonField()\n\nsettings.py:\n\nLOGGING = {\n    'version': 1,\n    'handlers': {\n        'console': {\n            'level': 'INFO',\n            'class': 'logging.StreamHandler',\n        },\n    },\n    'root': {\n        'handlers': ['console'],\n        'level': 'INFO',\n    }\n}\n\nmain.py:\n\nfrom app.models import Area\nArea.objects.filter(area__intersects='POLYGON ((1 1, 1 0, 0 0, 0 1, 1 1))')",
      "issue_closed_at": "2020-01-16T07:35:03",
      "base_commit": "1e0dcd6c8bfa4519c21014c73eb510620dd1a000",
      "changes": [
        {
          "file": "django/contrib/gis/gdal/raster/source.py",
          "type": "function",
          "name": "__init__",
          "class_name": "GDALRaster",
          "code": "def __init__(self, ds_input, write=False):\n        self._write = 1 if write else 0\n        Driver.ensure_registered()\n\n        # Preprocess json inputs. This converts json strings to dictionaries,\n        # which are parsed below the same way as direct dictionary inputs.\n        if isinstance(ds_input, str) and json_regex.match(ds_input):\n            ds_input = json.loads(ds_input)\n\n        # If input is a valid file path, try setting file as source.\n        if isinstance(ds_input, str):\n            try:\n                # GDALOpen will auto-detect the data source type.\n                self._ptr = capi.open_ds(force_bytes(ds_input), self._write)\n            except GDALException as err:\n                raise GDALException('Could not open the datasource at \"{}\" ({}).'.format(ds_input, err))\n        elif isinstance(ds_input, bytes):\n            # Create a new raster in write mode.\n            self._write = 1\n            # Get size of buffer.\n            size = sys.getsizeof(ds_input)\n            # Pass data to ctypes, keeping a reference to the ctypes object so\n            # that the vsimem file remains available until the GDALRaster is\n            # deleted.\n            self._ds_input = c_buffer(ds_input)\n            # Create random name to reference in vsimem filesystem.\n            vsi_path = os.path.join(VSI_FILESYSTEM_BASE_PATH, str(uuid.uuid4()))\n            # Create vsimem file from buffer.\n            capi.create_vsi_file_from_mem_buffer(\n                force_bytes(vsi_path),\n                byref(self._ds_input),\n                size,\n                VSI_TAKE_BUFFER_OWNERSHIP,\n            )\n            # Open the new vsimem file as a GDALRaster.\n            try:\n                self._ptr = capi.open_ds(force_bytes(vsi_path), self._write)\n            except GDALException:\n                # Remove the broken file from the VSI filesystem.\n                capi.unlink_vsi_file(force_bytes(vsi_path))\n                raise GDALException('Failed creating VSI raster from the input buffer.')\n        elif isinstance(ds_input, dict):\n            # A new raster needs to be created in write mode\n            self._write = 1\n\n            # Create driver (in memory by default)\n            driver = Driver(ds_input.get('driver', 'MEM'))\n\n            # For out of memory drivers, check filename argument\n            if driver.name != 'MEM' and 'name' not in ds_input:\n                raise GDALException('Specify name for creation of raster with driver \"{}\".'.format(driver.name))\n\n            # Check if width and height where specified\n            if 'width' not in ds_input or 'height' not in ds_input:\n                raise GDALException('Specify width and height attributes for JSON or dict input.')\n\n            # Check if srid was specified\n            if 'srid' not in ds_input:\n                raise GDALException('Specify srid for JSON or dict input.')\n\n            # Create null terminated gdal options array.\n            papsz_options = []\n            for key, val in ds_input.get('papsz_options', {}).items():\n                option = '{}={}'.format(key, val)\n                papsz_options.append(option.upper().encode())\n            papsz_options.append(None)\n\n            # Convert papszlist to ctypes array.\n            papsz_options = (c_char_p * len(papsz_options))(*papsz_options)\n\n            # Create GDAL Raster\n            self._ptr = capi.create_ds(\n                driver._ptr,\n                force_bytes(ds_input.get('name', '')),\n                ds_input['width'],\n                ds_input['height'],\n                ds_input.get('nr_of_bands', len(ds_input.get('bands', []))),\n                ds_input.get('datatype', 6),\n                byref(papsz_options),\n            )\n\n            # Set band data if provided\n            for i, band_input in enumerate(ds_input.get('bands', [])):\n                band = self.bands[i]\n                if 'nodata_value' in band_input:\n                    band.nodata_value = band_input['nodata_value']\n                    # Instantiate band filled with nodata values if only\n                    # partial input data has been provided.\n                    if band.nodata_value is not None and (\n                            'data' not in band_input or\n                            'size' in band_input or\n                            'shape' in band_input):\n                        band.data(data=(band.nodata_value,), shape=(1, 1))\n                # Set band data values from input.\n                band.data(\n                    data=band_input.get('data'),\n                    size=band_input.get('size'),\n                    shape=band_input.get('shape'),\n                    offset=band_input.get('offset'),\n                )\n\n            # Set SRID\n            self.srs = ds_input.get('srid')\n\n            # Set additional properties if provided\n            if 'origin' in ds_input:\n                self.origin.x, self.origin.y = ds_input['origin']\n\n            if 'scale' in ds_input:\n                self.scale.x, self.scale.y = ds_input['scale']\n\n            if 'skew' in ds_input:\n                self.skew.x, self.skew.y = ds_input['skew']\n        elif isinstance(ds_input, c_void_p):\n            # Instantiate the object using an existing pointer to a gdal raster.\n            self._ptr = ds_input\n        else:\n            raise GDALException('Invalid data source input type: \"{}\".'.format(type(ds_input)))"
        },
        {
          "file": "django/contrib/gis/gdal/raster/source.py",
          "type": "function",
          "name": "vsi_buffer",
          "class_name": "GDALRaster",
          "code": "def vsi_buffer(self):\n        if not self.is_vsi_based:\n            return None\n        # Prepare an integer that will contain the buffer length.\n        out_length = c_int()\n        # Get the data using the vsi file name.\n        dat = capi.get_mem_buffer_from_vsi_file(\n            force_bytes(self.name),\n            byref(out_length),\n            VSI_DELETE_BUFFER_ON_READ,\n        )\n        # Read the full buffer pointer.\n        return string_at(dat, out_length.value)"
        }
      ]
    }
  ]
}