Skip to content
Snippets Groups Projects
Select Git revision
  • develop default protected
  • master
  • 1.0.1
  • 1121-download
  • plugins-v3
  • 876-http-signature
  • plugins-v2
  • plugins
  • 1.0.1
  • 1.0
  • 1.0-rc1
  • 0.21.2
  • 0.21.1
  • 0.21
  • 0.21-rc2
  • 0.21-rc1
  • 0.20.1
  • 0.20.0
  • 0.20.0-rc1
  • 0.19.1
  • 0.19.0
  • 0.19.0-rc2
  • 0.19.0-rc1
  • 0.18.3
  • 0.18.2
  • 0.18.1
  • 0.18
  • 0.17
28 results

utils.py

Blame
  • Forked from funkwhale / funkwhale
    6760 commits behind the upstream repository.
    utils.py 2.66 KiB
    import mimetypes
    import re
    
    import magic
    import mutagen
    from django.db.models import Q
    
    
    def normalize_query(
        query_string,
        findterms=re.compile(r'"([^"]+)"|(\S+)').findall,
        normspace=re.compile(r"\s{2,}").sub,
    ):
        """ Splits the query string in invidual keywords, getting rid of unecessary spaces
            and grouping quoted words together.
            Example:
    
            >>> normalize_query('  some random  words "with   quotes  " and   spaces')
            ['some', 'random', 'words', 'with quotes', 'and', 'spaces']
    
        """
        return [normspace(" ", (t[0] or t[1]).strip()) for t in findterms(query_string)]
    
    
    def get_query(query_string, search_fields):
        """ Returns a query, that is a combination of Q objects. That combination
            aims to search keywords within a model by testing the given search fields.
    
        """
        query = None  # Query to search for every search term
        terms = normalize_query(query_string)
        for term in terms:
            or_query = None  # Query to search for a given term in each field
            for field_name in search_fields:
                q = Q(**{"%s__icontains" % field_name: term})
                if or_query is None:
                    or_query = q
                else:
                    or_query = or_query | q
            if query is None:
                query = or_query
            else:
                query = query & or_query
        return query
    
    
    def guess_mimetype(f):
        b = min(1000000, f.size)
        t = magic.from_buffer(f.read(b), mime=True)
        if not t.startswith("audio/"):
            # failure, we try guessing by extension
            mt, _ = mimetypes.guess_type(f.path)
            if mt:
                t = mt
        return t
    
    
    def compute_status(jobs):
        statuses = jobs.order_by().values_list("status", flat=True).distinct()
        errored = any([status == "errored" for status in statuses])
        if errored:
            return "errored"
        pending = any([status == "pending" for status in statuses])
        if pending:
            return "pending"
        return "finished"
    
    
    AUDIO_EXTENSIONS_AND_MIMETYPE = [
        ("ogg", "audio/ogg"),
        ("mp3", "audio/mpeg"),
        ("flac", "audio/x-flac"),
    ]
    
    EXTENSION_TO_MIMETYPE = {ext: mt for ext, mt in AUDIO_EXTENSIONS_AND_MIMETYPE}
    MIMETYPE_TO_EXTENSION = {mt: ext for ext, mt in AUDIO_EXTENSIONS_AND_MIMETYPE}
    
    
    def get_ext_from_type(mimetype):
        return MIMETYPE_TO_EXTENSION.get(mimetype)
    
    
    def get_type_from_ext(extension):
        if extension.startswith("."):
            # we remove leading dot
            extension = extension[1:]
        return EXTENSION_TO_MIMETYPE.get(extension)
    
    
    def get_audio_file_data(f):
        data = mutagen.File(f)
        if not data:
            return
        d = {}
        d["bitrate"] = data.info.bitrate
        d["length"] = data.info.length
    
        return d