* ci(deployment): injecting secrets Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * fix: typo * feat(installation): Enterprise license check * fix(install): reset ee cli args Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * Fix typo * Update README.md * feat (tracker-axios): init plugin * fix (tracker-axios): version patch * Fixed alert's unknown metrics handler * fix (tracker-mobx): dev-dependencies and updated package-lock * feat: APIs for user session data deleteion - wip * fix: alert metric value of performance.speed_index * Build and deploy scripts for enterprise edition (#13) * feat(installation): enterprise installation * chore(install): enabling ansible gather_facts Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * chore(install): quotes for enterprise key Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * chore(installation): enterprise install dbs Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * chore(install): rename yaml * chore(install): change image tag Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * chore(install): License key variable added * chore(deployment): Injecting enterprise license key in workers. * chore(install): remove deprecated files * chore(install): make domain_name mandatory in vars.yaml Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * chore(actions): ee workers Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * feat(install): use local docker instead of crictl You can use the images built in the local machine, in installation, without putting that in any external registry. Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * feat: APIs for user session data deleteion * feat: prefix deleted mobs with DEL_ * feat: schedules to delete mobs * chore(ci): fix ee build Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * feat(build): passing build args to internal scripts Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * chore(install): moving kafka topic creation at the end Kafka pods usually takes time to be active. Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * chore(install): removing auth service. * chore(install): Adding rancher for cluster management * chore(install): proper name for alerts template * separate requirements and clean up * feat (frontend): typescript support * feat (tracker): 3.0.4: maintain baseURL & connAttempt options * feat(api): changed license validation * feat(api): ee-license fix for unprovided value * feat(api): fixed ee-signup cursor * feat(api): FOS fix replay-mob issue * feat(api): ee log ch-resources query * chore(ci): change openreplay-cli with kube-install.sh Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * ci(actions): change ee naming * feat(api): removed ch-logs * feat(install): injecting ee variables only on ee installation. Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * chore(install): remove licence key from ee Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * fix(install): ch values for chalice * feat(clickhouse): moved creation scripts to EE folder * fix (backend-ee): disable ios tables so far * chore(install): remove deprecated mandatory variables. Signed-off-by: Rajesh Rajendran <rjshrjndrn@gmail.com> * feat(api): remove duplicate files & changed signup * fix(backend-ee): ch prepare after commit * fix(backend-ee): syntax * feat(api): added missing EE tenant column * fix(scripts-ee): correct default clickhouse host * feat(api): changed version_number location * feat(api): ee log ch-errors query * feat(api): ee fix ch-errors query * feat: skip to issue button (#23) * feat(api): 🐛 ee fix ambiguous ch-error query & accounts endpoint * Feature: Autoplay Sessions (#22) * feat: autoplay sessions * change: removed unused import * auto play filter by tab * feat(api): changed JWT authorizer & API_KEY authorizer & fix undefined project_key * feat (backend-devops): Dockerfile for all services in one image * feat(sourcemap-uploader): --verbose argument use instead of --log * feat(api): log middleware * Feature - dom inspector (#28) * feat (frontend): typescript support * feat(frontend): DOM Inspector init * fix(frontend): use tailwind bg * feat(frontend dom-inspector): add element selection & deletion * fix(frontend): todo comment * di - styling wip * feature(di) - editor theme * feat(frontend): parse attributes with RE (+ability to add) * feature(di) - input width * fix(ui): di - review changes Co-authored-by: ShiKhu <alex.kaminsky.11@gmail.com> * chore(install): remove depricated init_dbs * feat(api): ee override multi-tenant-core * fix(frontend-build): gen css types before build * fix(ui) - checking for the license (#30) Co-authored-by: Rajesh Rajendran <rjshrjndrn@gmail.com> Co-authored-by: Mehdi Osman <estradino@users.noreply.github.com> Co-authored-by: ShiKhu <alex.kaminsky.11@gmail.com> Co-authored-by: KRAIEM Taha Yassine <tahayk2@gmail.com> Co-authored-by: Rajesh Rajendran <rjshrjndrn@users.noreply.github.com> Co-authored-by: ourvakan <hi-psi@yandex.com> Co-authored-by: tahayk2@gmail.com <enissay4ever4github>
128 lines
4.9 KiB
Python
128 lines
4.9 KiB
Python
import sentry_sdk
|
|
from chalice import Chalice, Response
|
|
from sentry_sdk import configure_scope
|
|
|
|
from chalicelib import _overrides
|
|
from chalicelib.blueprints import bp_authorizers
|
|
from chalicelib.blueprints import bp_core, bp_core_crons
|
|
from chalicelib.blueprints import bp_core_dynamic, bp_core_dynamic_crons
|
|
from chalicelib.blueprints.subs import bp_dashboard
|
|
from chalicelib.utils import helper
|
|
from chalicelib.utils import pg_client
|
|
from chalicelib.utils.helper import environ
|
|
|
|
from chalicelib.blueprints import bp_ee, bp_ee_crons
|
|
|
|
app = Chalice(app_name='parrot')
|
|
app.debug = not helper.is_production() or helper.is_local()
|
|
|
|
sentry_sdk.init(environ["sentryURL"])
|
|
|
|
# Monkey-patch print for DataDog hack
|
|
import sys
|
|
import traceback
|
|
|
|
old_tb = traceback.print_exception
|
|
old_f = sys.stdout
|
|
old_e = sys.stderr
|
|
OR_SESSION_TOKEN = None
|
|
|
|
|
|
class F:
|
|
def write(self, x):
|
|
if OR_SESSION_TOKEN is not None and x != '\n' and not helper.is_local():
|
|
old_f.write(f"[or_session_token={OR_SESSION_TOKEN}] {x}")
|
|
else:
|
|
old_f.write(x)
|
|
|
|
def flush(self):
|
|
pass
|
|
|
|
|
|
def tb_print_exception(etype, value, tb, limit=None, file=None, chain=True):
|
|
if OR_SESSION_TOKEN is not None and not helper.is_local():
|
|
value = type(value)(f"[or_session_token={OR_SESSION_TOKEN}] " + str(value))
|
|
|
|
old_tb(etype, value, tb, limit, file, chain)
|
|
|
|
|
|
if helper.is_production():
|
|
traceback.print_exception = tb_print_exception
|
|
|
|
sys.stdout = F()
|
|
sys.stderr = F()
|
|
# ---End Monkey-patch
|
|
|
|
|
|
_overrides.chalice_app(app)
|
|
|
|
|
|
@app.middleware('http')
|
|
def or_middleware(event, get_response):
|
|
from chalicelib.ee import unlock
|
|
if not unlock.is_valid():
|
|
return Response(body={"errors": ["expired license"]}, status_code=403)
|
|
if "{projectid}" in event.path.lower():
|
|
from chalicelib.ee import projects
|
|
print("==================================")
|
|
print(event.context["authorizer"].get("authorizer_identity"))
|
|
print(event.uri_params["projectId"])
|
|
print(projects.get_internal_project_id(event.uri_params["projectId"]))
|
|
print(event.context["authorizer"]["tenantId"])
|
|
print("==================================")
|
|
if event.context["authorizer"].get("authorizer_identity") == "api_key" \
|
|
and not projects.is_authorized(
|
|
project_id=projects.get_internal_project_id(event.uri_params["projectId"]),
|
|
tenant_id=event.context["authorizer"]["tenantId"]) \
|
|
or event.context["authorizer"].get("authorizer_identity", "jwt") == "jwt" \
|
|
and not projects.is_authorized(project_id=event.uri_params["projectId"],
|
|
tenant_id=event.context["authorizer"]["tenantId"]):
|
|
print("unauthorized project")
|
|
pg_client.close()
|
|
return Response(body={"errors": ["unauthorized project"]}, status_code=401)
|
|
global OR_SESSION_TOKEN
|
|
OR_SESSION_TOKEN = app.current_request.headers.get('vnd.openreplay.com.sid',
|
|
app.current_request.headers.get('vnd.asayer.io.sid'))
|
|
if "authorizer" in event.context and event.context["authorizer"] is None:
|
|
print("Deleted user!!")
|
|
pg_client.close()
|
|
return Response(body={"errors": ["Deleted user"]}, status_code=403)
|
|
|
|
try:
|
|
if helper.TRACK_TIME:
|
|
import time
|
|
now = int(time.time() * 1000)
|
|
response = get_response(event)
|
|
if response.status_code == 500 and helper.allow_sentry() and OR_SESSION_TOKEN is not None and not helper.is_local():
|
|
with configure_scope() as scope:
|
|
scope.set_tag('stage', environ["stage"])
|
|
scope.set_tag('openReplaySessionToken', OR_SESSION_TOKEN)
|
|
scope.set_extra("context", event.context)
|
|
sentry_sdk.capture_exception(Exception(response.body))
|
|
if helper.TRACK_TIME:
|
|
print(f"Execution time: {int(time.time() * 1000) - now} ms")
|
|
except Exception as e:
|
|
if helper.allow_sentry() and OR_SESSION_TOKEN is not None and not helper.is_local():
|
|
with configure_scope() as scope:
|
|
scope.set_tag('stage', environ["stage"])
|
|
scope.set_tag('openReplaySessionToken', OR_SESSION_TOKEN)
|
|
scope.set_extra("context", event.context)
|
|
sentry_sdk.capture_exception(e)
|
|
response = Response(body={"Code": "InternalServerError",
|
|
"Message": "An internal server error occurred [level=Fatal]."},
|
|
status_code=500)
|
|
pg_client.close()
|
|
return response
|
|
|
|
|
|
# Open source
|
|
app.register_blueprint(bp_authorizers.app)
|
|
app.register_blueprint(bp_core.app)
|
|
app.register_blueprint(bp_core_crons.app)
|
|
app.register_blueprint(bp_core_dynamic.app)
|
|
app.register_blueprint(bp_core_dynamic_crons.app)
|
|
app.register_blueprint(bp_dashboard.app)
|
|
|
|
# Enterprise
|
|
app.register_blueprint(bp_ee.app)
|
|
app.register_blueprint(bp_ee_crons.app)
|