Exemple #1
0
def snugglefish_search(indexes, search, user):
    """Execute search of selected index with the given string."""

    # Return a dictionary where the key is the index name and the
    # value a dictionary with status and a list of potential matches.
    ret = {}

    # If there are no sources, return early.
    sources = user_sources(user)
    if not sources:
        return ret

    for idx in indexes:
        ret[idx] = {'success': True, 'reason': '', 'files': []}
        sngindex = SnuggleIndex.objects(name=idx).first()
        if not sngindex:
            ret[idx]['reason'] = "Index not found in database."
            ret[idx]['success'] = False
            continue
        snuggle = pysnugglefish.init(str(sngindex.directory + "/" + idx))
        try:
            tmp = snuggle.search(search)
            for res in tmp:
                if Sample.objects(md5=res,
                                  source__name__in=sources).count() > 0:
                    ret[idx]['files'].append(res)
        except Exception, e:
            ret[idx]['reason'] = "Error: %s" % e
            ret[idx]['success'] = False
Exemple #2
0
def snugglefish_search(indexes, search, user):
    """Execute search of selected index with the given string."""

    # Return a dictionary where the key is the index name and the
    # value a dictionary with status and a list of potential matches.
    ret = {}

    # If there are no sources, return early.
    sources = user_sources(user)
    if not sources:
        return ret

    for idx in indexes:
        ret[idx] = {
                     'success': True,
                     'reason': '',
                     'files': []
                   }
        sngindex = SnuggleIndex.objects(name=idx).first()
        if not sngindex:
            ret[idx]['reason'] = "Index not found in database."
            ret[idx]['success'] = False
            continue
        snuggle = pysnugglefish.init(str(sngindex.directory + "/" + idx))
        try:
            tmp = snuggle.search(search)
            for res in tmp:
                if Sample.objects(md5=res, source__name__in=sources).count() > 0:
                    ret[idx]['files'].append(res)
        except Exception, e:
            ret[idx]['reason'] = "Error: %s" % e
            ret[idx]['success'] = False
Exemple #3
0
def main():
    cpu_count = multiprocessing.cpu_count()

    parser = OptionParser()
    parser.add_option("-i",
                      "--index",
                      action="store_true",
                      dest="index",
                      default=None,
                      help="Index operation.")
    parser.add_option("-s",
                      "--search",
                      action="store_true",
                      dest="search",
                      default=None,
                      help="Search operation.")
    parser.add_option("-I",
                      "--indexfile",
                      action="store",
                      dest="indexfile",
                      default="",
                      help="Index file to search or create.")
    parser.add_option("-t",
                      "--threads",
                      action="store",
                      dest="threads",
                      default=cpu_count,
                      help="Number of threads to spawn (default is #cpus).")

    (opts, searchstring) = parser.parse_args()

    if (not opts.index and not opts.search) or (opts.index and opts.search):
        print "[!] Must specify one of index or search."
        return

    if not opts.indexfile:
        print "[!] Must specify output location"
        return

    s = pysnugglefish.init(opts.indexfile)

    try:
        threads = int(opts.threads)
    except Exception as e:
        print "[!] Invalid threads: %s" % e.message
        return

    if threads <= 0:
        print "[!] Invalid threads. Defaulting to %i." % cpu_count
        threads = cpu_count

    if opts.index:
        s.file_list = [line.rstrip('\n') for line in sys.stdin.readlines()]
        msg = "[+] Indexing %i files with %i threads." % (len(
            s.file_list), threads)
        print "[+] This might take a while... ;)"
        try:
            s.make_index(threads)
        except Exception as e:
            print "[!] Exception while indexing: %s" % e.message
    elif opts.search:
        searchstring = ' '.join(searchstring)
        if not searchstring:
            searchstring = raw_input("Search string: ")

        if not searchstring:
            print "[!] Must enter a search string."
            return

        print "[+] Searching for %s with %i threads" % (searchstring, threads)
        try:
            results = s.search(searchstring, threads)
            for result in results:
                print result
        except Exception as e:
            print "[!] Exception while searching: %s" % e.message
Exemple #4
0
def main():
    cpu_count = multiprocessing.cpu_count()

    parser = OptionParser()
    parser.add_option("-i", "--index", action="store_true", dest="index",
                      default=None, help="Index operation.")
    parser.add_option("-s", "--search", action="store_true", dest="search",
                      default=None, help="Search operation.")
    parser.add_option("-I", "--indexfile", action="store", dest="indexfile",
                      default="", help="Index file to search or create.")
    parser.add_option("-t", "--threads", action="store", dest="threads",
                      default=cpu_count,
                      help="Number of threads to spawn (default is #cpus).")

    (opts, searchstring) = parser.parse_args()

    if (not opts.index and not opts.search) or (opts.index and opts.search):
        print "[!] Must specify one of index or search."
        return

    if not opts.indexfile:
        print "[!] Must specify output location"
        return

    s = pysnugglefish.init(opts.indexfile)

    try:
        threads = int(opts.threads)
    except Exception as e:
        print "[!] Invalid threads: %s" % e.message
        return

    if threads <= 0:
        print "[!] Invalid threads. Defaulting to %i." % cpu_count
        threads = cpu_count

    if opts.index:
        s.file_list = [ line.rstrip('\n') for line in sys.stdin.readlines() ]
        msg = "[+] Indexing %i files with %i threads." % (len(s.file_list),
                                                          threads)
        print "[+] This might take a while... ;)"
        try:
            s.make_index(threads)
        except Exception as e:
            print "[!] Exception while indexing: %s" % e.message
    elif opts.search:
        searchstring = ' '.join(searchstring)
        if not searchstring:
            searchstring = raw_input("Search string: ")

        if not searchstring:
            print "[!] Must enter a search string."
            return

        print "[+] Searching for %s with %i threads" % (searchstring, threads)
        try:
            results = s.search(searchstring, threads)
            for result in results:
                print result
        except Exception as e:
            print "[!] Exception while searching: %s" % e.message