mirror of https://github.com/CIRCL/lookyloo
chg: Remove refs to splash
parent
a8722bab57
commit
cc17b414ff
|
@ -2,7 +2,6 @@
|
||||||
import hashlib
|
import hashlib
|
||||||
import json
|
import json
|
||||||
import logging
|
import logging
|
||||||
import os
|
|
||||||
import pkg_resources
|
import pkg_resources
|
||||||
|
|
||||||
from datetime import datetime, timedelta
|
from datetime import datetime, timedelta
|
||||||
|
@ -10,20 +9,18 @@ from enum import IntEnum, unique
|
||||||
from functools import lru_cache
|
from functools import lru_cache
|
||||||
from io import BufferedIOBase
|
from io import BufferedIOBase
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
from typing import Any, Dict, List, Optional, Set, Tuple, Union
|
from typing import Any, Dict, List, Optional, Set, Union
|
||||||
from urllib.parse import urljoin, urlparse
|
from urllib.parse import urlparse
|
||||||
|
|
||||||
import requests
|
|
||||||
|
|
||||||
from har2tree import CrawledTree, HostNode, URLNode
|
from har2tree import CrawledTree, HostNode, URLNode
|
||||||
from publicsuffix2 import PublicSuffixList, fetch # type: ignore
|
from publicsuffix2 import PublicSuffixList, fetch # type: ignore
|
||||||
from pytaxonomies import Taxonomies
|
from pytaxonomies import Taxonomies
|
||||||
from requests.exceptions import HTTPError
|
|
||||||
from ua_parser import user_agent_parser # type: ignore
|
from ua_parser import user_agent_parser # type: ignore
|
||||||
from werkzeug.user_agent import UserAgent
|
from werkzeug.user_agent import UserAgent
|
||||||
from werkzeug.utils import cached_property
|
from werkzeug.utils import cached_property
|
||||||
|
|
||||||
from .default import get_homedir, safe_create_dir, get_config
|
from .default import get_homedir, safe_create_dir
|
||||||
|
|
||||||
logger = logging.getLogger('Lookyloo - Helpers')
|
logger = logging.getLogger('Lookyloo - Helpers')
|
||||||
|
|
||||||
|
@ -135,7 +132,7 @@ def load_cookies(cookie_pseudofile: Optional[Union[BufferedIOBase, str]]=None) -
|
||||||
'value': cookie['Content raw']
|
'value': cookie['Content raw']
|
||||||
}
|
}
|
||||||
else:
|
else:
|
||||||
# Cookie from lookyloo/splash
|
# Cookie from lookyloo/playwright
|
||||||
to_add = cookie
|
to_add = cookie
|
||||||
to_return.append(to_add)
|
to_return.append(to_add)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
|
@ -157,30 +154,6 @@ def get_useragent_for_requests():
|
||||||
return f'Lookyloo / {version}'
|
return f'Lookyloo / {version}'
|
||||||
|
|
||||||
|
|
||||||
@lru_cache(64)
|
|
||||||
def get_splash_url() -> str:
|
|
||||||
if os.environ.get('SPLASH_URL_DOCKER'):
|
|
||||||
# In order to have a working default for the docker image, it is easier to use an environment variable
|
|
||||||
return os.environ['SPLASH_URL_DOCKER']
|
|
||||||
else:
|
|
||||||
return get_config('generic', 'splash_url')
|
|
||||||
|
|
||||||
|
|
||||||
def splash_status() -> Tuple[bool, str]:
|
|
||||||
try:
|
|
||||||
splash_status = requests.get(urljoin(get_splash_url(), '_ping'))
|
|
||||||
splash_status.raise_for_status()
|
|
||||||
json_status = splash_status.json()
|
|
||||||
if json_status['status'] == 'ok':
|
|
||||||
return True, 'Splash is up'
|
|
||||||
else:
|
|
||||||
return False, str(json_status)
|
|
||||||
except HTTPError as http_err:
|
|
||||||
return False, f'HTTP error occurred: {http_err}'
|
|
||||||
except Exception as err:
|
|
||||||
return False, f'Other error occurred: {err}'
|
|
||||||
|
|
||||||
|
|
||||||
def get_cache_directory(root: Path, identifier: str, namespace: Optional[str] = None) -> Path:
|
def get_cache_directory(root: Path, identifier: str, namespace: Optional[str] = None) -> Path:
|
||||||
m = hashlib.md5()
|
m = hashlib.md5()
|
||||||
m.update(identifier.encode())
|
m.update(identifier.encode())
|
||||||
|
|
|
@ -28,7 +28,7 @@ from .default import LookylooException, get_homedir, get_config, get_socket_path
|
||||||
from .exceptions import (MissingCaptureDirectory,
|
from .exceptions import (MissingCaptureDirectory,
|
||||||
MissingUUID, TreeNeedsRebuild, NoValidHarFile)
|
MissingUUID, TreeNeedsRebuild, NoValidHarFile)
|
||||||
from .helpers import (CaptureStatus, get_captures_dir, get_email_template,
|
from .helpers import (CaptureStatus, get_captures_dir, get_email_template,
|
||||||
get_resources_hashes, get_splash_url, get_taxonomies,
|
get_resources_hashes, get_taxonomies,
|
||||||
uniq_domains, ParsedUserAgent)
|
uniq_domains, ParsedUserAgent)
|
||||||
from .indexing import Indexing
|
from .indexing import Indexing
|
||||||
from .modules import (MISP, PhishingInitiative, UniversalWhois,
|
from .modules import (MISP, PhishingInitiative, UniversalWhois,
|
||||||
|
@ -48,7 +48,6 @@ class Lookyloo():
|
||||||
self.redis_pool: ConnectionPool = ConnectionPool(connection_class=UnixDomainSocketConnection,
|
self.redis_pool: ConnectionPool = ConnectionPool(connection_class=UnixDomainSocketConnection,
|
||||||
path=get_socket_path('cache'), decode_responses=True)
|
path=get_socket_path('cache'), decode_responses=True)
|
||||||
self.capture_dir: Path = get_captures_dir()
|
self.capture_dir: Path = get_captures_dir()
|
||||||
self.splash_url: str = get_splash_url()
|
|
||||||
|
|
||||||
self._priority = get_config('generic', 'priority')
|
self._priority = get_config('generic', 'priority')
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,6 @@ from rich.console import Console
|
||||||
from rich.padding import Padding
|
from rich.padding import Padding
|
||||||
|
|
||||||
from lookyloo.default import get_socket_path, AbstractManager
|
from lookyloo.default import get_socket_path, AbstractManager
|
||||||
from lookyloo.helpers import splash_status
|
|
||||||
|
|
||||||
# NOTE: run with watch:
|
# NOTE: run with watch:
|
||||||
# watch --color tools/monitoring.py
|
# watch --color tools/monitoring.py
|
||||||
|
@ -80,12 +79,6 @@ class Monitoring():
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
||||||
status, message = splash_status()
|
|
||||||
if status:
|
|
||||||
console.print(f'[green]{message}[/green]')
|
|
||||||
else:
|
|
||||||
console.print('Splash is [bold red]down[/bold red]: ', message)
|
|
||||||
|
|
||||||
m = Monitoring()
|
m = Monitoring()
|
||||||
backend_up = m.backend_status
|
backend_up = m.backend_status
|
||||||
if not backend_up:
|
if not backend_up:
|
||||||
|
|
|
@ -10,7 +10,6 @@ from flask import request, send_file
|
||||||
from flask_restx import Namespace, Resource, abort, fields # type: ignore
|
from flask_restx import Namespace, Resource, abort, fields # type: ignore
|
||||||
from werkzeug.security import check_password_hash
|
from werkzeug.security import check_password_hash
|
||||||
|
|
||||||
from lookyloo.helpers import splash_status
|
|
||||||
from lookyloo.lookyloo import Lookyloo
|
from lookyloo.lookyloo import Lookyloo
|
||||||
|
|
||||||
from .helpers import build_users_table, load_user_from_request, src_request_ip
|
from .helpers import build_users_table, load_user_from_request, src_request_ip
|
||||||
|
@ -58,14 +57,6 @@ class AuthToken(Resource):
|
||||||
return {'error': 'User/Password invalid.'}, 401
|
return {'error': 'User/Password invalid.'}, 401
|
||||||
|
|
||||||
|
|
||||||
@api.route('/json/splash_status')
|
|
||||||
@api.doc(description='Get status of splash.')
|
|
||||||
class SplashStatus(Resource):
|
|
||||||
def get(self):
|
|
||||||
status, info = splash_status()
|
|
||||||
return {'is_up': status, 'info': info}
|
|
||||||
|
|
||||||
|
|
||||||
@api.route('/json/<string:capture_uuid>/status')
|
@api.route('/json/<string:capture_uuid>/status')
|
||||||
@api.doc(description='Get the status of a capture',
|
@api.doc(description='Get the status of a capture',
|
||||||
params={'capture_uuid': 'The UUID of the capture'})
|
params={'capture_uuid': 'The UUID of the capture'})
|
||||||
|
|
Loading…
Reference in New Issue