mirror of https://github.com/CIRCL/AIL-framework
				
				
				
			
		
			
				
	
	
		
			87 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
| #!/usr/bin/env python3
 | |
| # -*-coding:UTF-8 -*
 | |
| 
 | |
| '''
 | |
|     Blueprint Flask: crawler splash endpoints: dashboard, onion crawler ...
 | |
| '''
 | |
| 
 | |
| import os
 | |
| import sys
 | |
| 
 | |
| from flask import render_template, jsonify, request, Blueprint, redirect, url_for, Response, abort
 | |
| from flask_login import login_required, current_user
 | |
| 
 | |
| # Import Role_Manager
 | |
| from Role_Manager import login_admin, login_analyst, login_read_only
 | |
| 
 | |
| sys.path.append(os.environ['AIL_BIN'])
 | |
| ##################################
 | |
| # Import Project packages
 | |
| ##################################
 | |
| from lib.objects import CookiesNames
 | |
| from packages import Date
 | |
| 
 | |
| # ============ BLUEPRINT ============
 | |
| objects_cookie_name = Blueprint('objects_cookie_name', __name__, template_folder=os.path.join(os.environ['AIL_FLASK'], 'templates/objects/cookie-name'))
 | |
| 
 | |
| # ============ VARIABLES ============
 | |
| bootstrap_label = ['primary', 'success', 'danger', 'warning', 'info']
 | |
| 
 | |
| 
 | |
| # ============ FUNCTIONS ============
 | |
| @objects_cookie_name.route("/objects/cookie-name", methods=['GET'])
 | |
| @login_required
 | |
| @login_read_only
 | |
| def objects_cookies_names():
 | |
|     date_from = request.args.get('date_from')
 | |
|     date_to = request.args.get('date_to')
 | |
|     show_objects = request.args.get('show_objects')
 | |
|     date = Date.sanitise_date_range(date_from, date_to)
 | |
|     date_from = date['date_from']
 | |
|     date_to = date['date_to']
 | |
| 
 | |
|     if show_objects:
 | |
|         dict_objects = CookiesNames.CookiesNames().api_get_meta_by_daterange(date_from, date_to)
 | |
|     else:
 | |
|         dict_objects = {}
 | |
| 
 | |
|     return render_template("CookieNameDaterange.html", date_from=date_from, date_to=date_to,
 | |
|                            dict_objects=dict_objects, show_objects=show_objects)
 | |
| 
 | |
| @objects_cookie_name.route("/objects/cookie-name/post", methods=['POST'])
 | |
| @login_required
 | |
| @login_read_only
 | |
| def objects_cookies_names_post():
 | |
|     date_from = request.form.get('date_from')
 | |
|     date_to = request.form.get('date_to')
 | |
|     show_objects = request.form.get('show_objects')
 | |
|     return redirect(url_for('objects_cookie_name.objects_cookies_names', date_from=date_from, date_to=date_to, show_objects=show_objects))
 | |
| 
 | |
| @objects_cookie_name.route("/objects/cookie-name/range/json", methods=['GET'])
 | |
| @login_required
 | |
| @login_read_only
 | |
| def objects_cookie_name_range_json():
 | |
|     date_from = request.args.get('date_from')
 | |
|     date_to = request.args.get('date_to')
 | |
|     date = Date.sanitise_date_range(date_from, date_to)
 | |
|     date_from = date['date_from']
 | |
|     date_to = date['date_to']
 | |
|     return jsonify(CookiesNames.CookiesNames().api_get_chart_nb_by_daterange(date_from, date_to))
 | |
| 
 | |
| # @objects_cookie_name.route("/objects/cookie-nam/search", methods=['POST'])
 | |
| # @login_required
 | |
| # @login_read_only
 | |
| # def objects_cookies_names_search():
 | |
| #     to_search = request.form.get('object_id')
 | |
| #
 | |
| #     # TODO SANITIZE ID
 | |
| #     # TODO Search all
 | |
| #     cve = Cves.Cve(to_search)
 | |
| #     if not cve.exists():
 | |
| #         abort(404)
 | |
| #     else:
 | |
| #         return redirect(cve.get_link(flask_context=True))
 | |
| 
 | |
| # ============= ROUTES ==============
 | |
| 
 |