Compare commits

..

No commits in common. "main" and "may23_2025" have entirely different histories.

21 changed files with 143 additions and 371 deletions

View File

@ -1,12 +1,7 @@
from web3 import Web3
import time
from web3.exceptions import TimeExhausted,TransactionNotFound
from .models import FailedTransactions
from django.contrib.auth import get_user_model
User = get_user_model()
PRIVATE_KEY = "2c7c09807b78128e00a2ed308c122a0ecc45847ffe0195eca4b4d2463fb11549"
# PRIVATE_KEY = "6f06e1108b833b1918067042e13e60eda262705b80385a02d0330ce0db31d3ad"
# test network
# RPC = 'https://rpc-amoy.polygon.technology/'
@ -15,8 +10,8 @@ PRIVATE_KEY = "2c7c09807b78128e00a2ed308c122a0ecc45847ffe0195eca4b4d2463fb11549"
# ABI = '[ { "inputs": [], "stateMutability": "nonpayable", "type": "constructor" }, { "anonymous": false, "inputs": [ { "indexed": false, "internalType": "uint256", "name": "user_id", "type": "uint256" }, { "indexed": false, "internalType": "string", "name": "project", "type": "string" }, { "indexed": false, "internalType": "string", "name": "data", "type": "string" } ], "name": "conversion", "type": "event" }, { "inputs": [ { "internalType": "address", "name": "pubkey", "type": "address" }, { "internalType": "uint256", "name": "user_id", "type": "uint256" }, { "internalType": "string", "name": "project", "type": "string" } ], "name": "deleteConversion", "outputs": [], "stateMutability": "nonpayable", "type": "function" }, { "inputs": [ { "internalType": "address", "name": "pubKey", "type": "address" }, { "internalType": "uint256", "name": "user_id", "type": "uint256" }, { "internalType": "string", "name": "project", "type": "string" }, { "internalType": "string", "name": "_data", "type": "string" } ], "name": "UploadConversionData", "outputs": [], "stateMutability": "nonpayable", "type": "function" }, { "inputs": [ { "internalType": "uint256", "name": "user_id", "type": "uint256" }, { "internalType": "string", "name": "project", "type": "string" } ], "name": "getConversion", "outputs": [ { "components": [ { "internalType": "address", "name": "owner", "type": "address" }, { "internalType": "string", "name": "mydata", "type": "string" }, { "internalType": "bool", "name": "Write", "type": "bool" } ], "internalType": "struct scriptConversionDataBase.privateData", "name": "", "type": "tuple" } ], "stateMutability": "view", "type": "function" }, { "inputs": [ { "internalType": "uint256", "name": "userId", "type": "uint256" } ], "name": "getProjectId", "outputs": [ { "internalType": "string[]", "name": "", "type": "string[]" } ], "stateMutability": "view", "type": "function" } ]'
# # mainnet
RPC = 'https://polygon-rpc.com'
# RPC = "https://polygon-mainnet.infura.io/v3/017957497a0d4e9c80750c18a431ac1e"
# RPC = 'https://polygon-rpc.com'
RPC = "https://polygon-mainnet.infura.io/v3/017957497a0d4e9c80750c18a431ac1e"
CONTRACT_ADDRESS = '0x552453F2C4e8ED860a6AEC7D6Bde143CF86E396a'
CHAIN_ID = 137
ABI = '[ { "inputs": [], "stateMutability": "nonpayable", "type": "constructor" }, { "anonymous": false, "inputs": [ { "indexed": false, "internalType": "uint256", "name": "user_id", "type": "uint256" }, { "indexed": false, "internalType": "string", "name": "project", "type": "string" }, { "indexed": false, "internalType": "string", "name": "data", "type": "string" } ], "name": "conversion", "type": "event" }, { "inputs": [ { "internalType": "address", "name": "pubkey", "type": "address" }, { "internalType": "uint256", "name": "user_id", "type": "uint256" }, { "internalType": "string", "name": "project", "type": "string" } ], "name": "deleteConversion", "outputs": [], "stateMutability": "nonpayable", "type": "function" }, { "inputs": [ { "internalType": "address", "name": "pubKey", "type": "address" }, { "internalType": "uint256", "name": "user_id", "type": "uint256" }, { "internalType": "string", "name": "project", "type": "string" }, { "internalType": "string", "name": "_data", "type": "string" } ], "name": "UploadConversionData", "outputs": [], "stateMutability": "nonpayable", "type": "function" }, { "inputs": [ { "internalType": "uint256", "name": "user_id", "type": "uint256" }, { "internalType": "string", "name": "project", "type": "string" } ], "name": "getConversion", "outputs": [ { "components": [ { "internalType": "address", "name": "owner", "type": "address" }, { "internalType": "string", "name": "mydata", "type": "string" }, { "internalType": "bool", "name": "Write", "type": "bool" } ], "internalType": "struct scriptConversionDataBase.privateData", "name": "", "type": "tuple" } ], "stateMutability": "view", "type": "function" }, { "inputs": [ { "internalType": "uint256", "name": "userId", "type": "uint256" } ], "name": "getProjectId", "outputs": [ { "internalType": "string[]", "name": "", "type": "string[]" } ], "stateMutability": "view", "type": "function" } ]'
@ -29,9 +24,10 @@ contractInst = web3.eth.contract(address=CAddress, abi=abi)
def UploadConversionData(privatekey,pubkey, user_id,project,data):
try:
acc1 = web3.eth.account.from_key(PRIVATE_KEY).address
def send_transaction( gas_price):
nonce = web3.eth.get_transaction_count(acc1,'pending') # Get nonce including pending transactions
uploadData = contractInst.functions.UploadConversionData(pubkey, user_id, project, data).build_transaction({
'gasPrice': web3.eth.gas_price,
'gasPrice': gas_price,
'chainId': CHAIN_ID,
'from': acc1,
'nonce': nonce
@ -39,104 +35,58 @@ def UploadConversionData(privatekey,pubkey, user_id,project,data):
signed_transaction = web3.eth.account.sign_transaction(uploadData, private_key=PRIVATE_KEY)
transaction_hash = web3.eth.send_raw_transaction(signed_transaction.rawTransaction)
print("Transaction hash:", transaction_hash.hex())
return transaction_hash
try:
acc1 = web3.eth.account.from_key(PRIVATE_KEY).address
initial_gas_price = web3.eth.gas_price
max_retries = 4
retries = 0
transaction_hash = None
try:
transaction_hash = send_transaction(initial_gas_price)
except ValueError as e:
# If the error is due to "replacement transaction underpriced", handle it
if "replacement transaction underpriced" in str(e):
print("Initial transaction attempt failed due to 'replacement transaction underpriced'. Retrying with higher gas price.")
retries += 1
new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
transaction_hash = send_transaction(new_gas_price)
elif "max fee per gas less than block base fee" in str(e):
print("Initial transaction attempt failed due to 'max fee per gas less than block base fee'. Retrying with higher gas price.")
retries += 1
new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
transaction_hash = send_transaction(new_gas_price)
else:
raise
while retries < max_retries and transaction_hash:
try:
transaction_receipt = web3.eth.wait_for_transaction_receipt(transaction_hash, timeout=120)
print("Transaction confirmed:")
break
except TimeExhausted:
retries += 1
print(f"Transaction not confirmed in {120 * retries} seconds, retrying... ({retries}/{max_retries})")
# Increase the gas price by 10% for each retry
new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
transaction_hash = send_transaction(new_gas_price)
else:
if retries == max_retries:
print("Failed to confirm the transaction after multiple attempts.")
raise TimeoutError("Failed to confirm the transaction after multiple attempts.")
transaction_fee = transaction_receipt.effectiveGasPrice * transaction_receipt.gasUsed
tx_id = transaction_hash.hex()
# Check if the transaction was successful
if transaction_receipt.status == 1:
print("Transaction successful!")
return tx_id, str(transaction_fee)
else:
print("Transaction failed!")
obj,_ = FailedTransactions.objects.get_or_create(service_id=project,service_name="Conversion")
creator = User.objects.get(id=user_id)
obj.creator = creator
obj.transaction_type = "UploadConversionData"
obj.transaction_hash = ""
obj.transaction_status = "failed"
obj.transaction_error = "Transaction failed"
obj.transaction_data = str(data)
obj.save()
return False, "Transaction failed"
except Exception as e:
print(f"An error occurred: {e}")
raise
except Exception as e:
print({"error":str(e)})
obj,_ = FailedTransactions.objects.get_or_create(service_id=project,service_name="Conversion")
creator = User.objects.get(id=user_id)
obj.creator = creator
obj.transaction_type = "UploadConversionData"
obj.transaction_hash = ""
obj.transaction_status = "failed"
obj.transaction_error = str(e)
obj.transaction_data = str(data)
obj.save()
return False, str(e)
# def UploadConversionData(privatekey,pubkey, user_id,project,data):
# try:
# acc1 = web3.eth.account.from_key(PRIVATE_KEY).address
# def send_transaction( gas_price):
# nonce = web3.eth.get_transaction_count(acc1,'pending') # Get nonce including pending transactions
# uploadData = contractInst.functions.UploadConversionData(pubkey, user_id, project, data).build_transaction({
# 'gasPrice': gas_price,
# 'chainId': CHAIN_ID,
# 'from': acc1,
# 'nonce': nonce
# })
# signed_transaction = web3.eth.account.sign_transaction(uploadData, private_key=PRIVATE_KEY)
# transaction_hash = web3.eth.send_raw_transaction(signed_transaction.rawTransaction)
# print("Transaction hash:", transaction_hash.hex())
# return transaction_hash
# try:
# acc1 = web3.eth.account.from_key(PRIVATE_KEY).address
# initial_gas_price = web3.eth.gas_price
# max_retries = 4
# retries = 0
# transaction_hash = None
# try:
# transaction_hash = send_transaction(initial_gas_price)
# except ValueError as e:
# # If the error is due to "replacement transaction underpriced", handle it
# if "replacement transaction underpriced" in str(e):
# print("Initial transaction attempt failed due to 'replacement transaction underpriced'. Retrying with higher gas price.")
# retries += 1
# new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
# transaction_hash = send_transaction(new_gas_price)
# elif "max fee per gas less than block base fee" in str(e):
# print("Initial transaction attempt failed due to 'max fee per gas less than block base fee'. Retrying with higher gas price.")
# retries += 1
# new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
# transaction_hash = send_transaction(new_gas_price)
# else:
# raise
# while retries < max_retries and transaction_hash:
# try:
# transaction_receipt = web3.eth.wait_for_transaction_receipt(transaction_hash, timeout=120)
# print("Transaction confirmed:")
# break
# except TimeExhausted:
# retries += 1
# print(f"Transaction not confirmed in {120 * retries} seconds, retrying... ({retries}/{max_retries})")
# # Increase the gas price by 10% for each retry
# new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
# transaction_hash = send_transaction(new_gas_price)
# else:
# if retries == max_retries:
# print("Failed to confirm the transaction after multiple attempts.")
# raise TimeoutError("Failed to confirm the transaction after multiple attempts.")
# transaction_fee = transaction_receipt.effectiveGasPrice * transaction_receipt.gasUsed
# tx_id = transaction_hash.hex()
# return tx_id, str(transaction_fee)
# except Exception as e:
# print(f"An error occurred: {e}")
# raise
# except Exception as e:
# print({"error":str(e)})
# return e
return e
def getConversion(private_key,user_id,project):
ACCOUNT = web3.eth.account.from_key(private_key).address

View File

@ -1,14 +1,7 @@
from web3 import Web3
import time
from web3.exceptions import TimeExhausted,TransactionNotFound
from .models import FailedTransactions
from django.contrib.auth import get_user_model
User = get_user_model()
PRIVATE_KEY = "a632f28406579d96879cfc49d55411bb1424dbbae60bf4dd93ad0710b63d6b80"
# PRIVATE_KEY = "6f06e1108b833b1918067042e13e60eda262705b80385a02d0330ce0db31d3ad"
# RPC = 'https://rpc-amoy.polygon.technology/'
# CONTRACT_ADDRESS = '0xbE91e2294D12fa78Ce64657fD9Ee137cE3e99881'
@ -27,75 +20,13 @@ CAddress =CONTRACT_ADDRESS
abi = ABI
contractInst = web3.eth.contract(address=CAddress, abi=abi)
# def UploadScriptAuditData(privatekey,pubkey,user_id,project,data):
# try:
# acc1 = web3.eth.account.from_key(PRIVATE_KEY).address
# def send_transaction( gas_price):
# nonce = web3.eth.get_transaction_count(acc1,'pending') # Get nonce including pending transactions
# uploadData = contractInst.functions.UploadScriptAuditData(pubkey, user_id, project, data).build_transaction({
# 'gasPrice': gas_price,
# 'chainId': CHAIN_ID,
# 'from': acc1,
# 'nonce': nonce
# })
# signed_transaction = web3.eth.account.sign_transaction(uploadData, private_key=PRIVATE_KEY)
# transaction_hash = web3.eth.send_raw_transaction(signed_transaction.rawTransaction)
# print("Transaction hash:", transaction_hash.hex())
# return transaction_hash
# acc1 = web3.eth.account.from_key(PRIVATE_KEY).address
# initial_gas_price = web3.eth.gas_price
# max_retries = 4
# retries = 0
# transaction_hash = None
# try:
# transaction_hash = send_transaction(initial_gas_price)
# except ValueError as e:
# # If the error is due to "replacement transaction underpriced", handle it
# if "replacement transaction underpriced" in str(e):
# print("Initial transaction attempt failed due to 'replacement transaction underpriced'. Retrying with higher gas price.")
# retries += 1
# new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
# transaction_hash = send_transaction(new_gas_price)
# elif "max fee per gas less than block base fee" in str(e):
# print("Initial transaction attempt failed due to 'max fee per gas less than block base fee'. Retrying with higher gas price.")
# retries += 1
# new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
# transaction_hash = send_transaction(new_gas_price)
# else:
# raise
# while retries < max_retries and transaction_hash:
# try:
# transaction_receipt = web3.eth.wait_for_transaction_receipt(transaction_hash, timeout=120)
# print("Transaction confirmed:")
# break
# except TimeExhausted:
# retries += 1
# print(f"Transaction not confirmed in {120 * retries} seconds, retrying... ({retries}/{max_retries})")
# # Increase the gas price by 10% for each retry
# new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
# transaction_hash = send_transaction(new_gas_price)
# else:
# if retries == max_retries:
# print("Failed to confirm the transaction after multiple attempts.")
# raise TimeoutError("Failed to confirm the transaction after multiple attempts.")
# transaction_fee = transaction_receipt.effectiveGasPrice * transaction_receipt.gasUsed
# tx_id = transaction_hash.hex()
# return tx_id, str(transaction_fee)
# except Exception as e:
# print({"error":str(e)})
# return e
def UploadScriptAuditData(privatekey,pubkey,user_id,project,data):
user = User.objects.get(id=user_id)
try:
acc1 = web3.eth.account.from_key(PRIVATE_KEY).address
def send_transaction( gas_price):
nonce = web3.eth.get_transaction_count(acc1,'pending') # Get nonce including pending transactions
uploadData = contractInst.functions.UploadScriptAuditData(pubkey, user_id, project, data).build_transaction({
'gasPrice': web3.eth.gas_price,
'gasPrice': gas_price,
'chainId': CHAIN_ID,
'from': acc1,
'nonce': nonce
@ -103,37 +34,53 @@ def UploadScriptAuditData(privatekey,pubkey,user_id,project,data):
signed_transaction = web3.eth.account.sign_transaction(uploadData, private_key=PRIVATE_KEY)
transaction_hash = web3.eth.send_raw_transaction(signed_transaction.rawTransaction)
print("Transaction hash:", transaction_hash.hex())
return transaction_hash
acc1 = web3.eth.account.from_key(PRIVATE_KEY).address
initial_gas_price = web3.eth.gas_price
max_retries = 4
retries = 0
transaction_hash = None
try:
transaction_hash = send_transaction(initial_gas_price)
except ValueError as e:
# If the error is due to "replacement transaction underpriced", handle it
if "replacement transaction underpriced" in str(e):
print("Initial transaction attempt failed due to 'replacement transaction underpriced'. Retrying with higher gas price.")
retries += 1
new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
transaction_hash = send_transaction(new_gas_price)
elif "max fee per gas less than block base fee" in str(e):
print("Initial transaction attempt failed due to 'max fee per gas less than block base fee'. Retrying with higher gas price.")
retries += 1
new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
transaction_hash = send_transaction(new_gas_price)
else:
raise
while retries < max_retries and transaction_hash:
try:
transaction_receipt = web3.eth.wait_for_transaction_receipt(transaction_hash, timeout=120)
print("Transaction confirmed:")
break
except TimeExhausted:
retries += 1
print(f"Transaction not confirmed in {120 * retries} seconds, retrying... ({retries}/{max_retries})")
# Increase the gas price by 10% for each retry
new_gas_price = int(web3.eth.gas_price * (1 + 0.1 * retries))
transaction_hash = send_transaction(new_gas_price)
else:
if retries == max_retries:
print("Failed to confirm the transaction after multiple attempts.")
raise TimeoutError("Failed to confirm the transaction after multiple attempts.")
transaction_fee = transaction_receipt.effectiveGasPrice * transaction_receipt.gasUsed
tx_id = transaction_hash.hex()
# Check if the transaction was successful
if transaction_receipt.status == 1:
print("Transaction successful!")
return tx_id, str(transaction_fee)
else:
print("Transaction failed!")
obj,_ = FailedTransactions.objects.get_or_create(service_id=project,service_name="ScriptAudit")
creator = User.objects.get(id=user_id)
obj.creator = creator
obj.transaction_type = "UploadScriptAuditData"
obj.transaction_hash = ""
obj.transaction_status = "failed"
obj.transaction_error = "Transaction failed"
obj.transaction_data = str(data)
obj.save()
return False, "Transaction failed"
except Exception as e:
print({"error":str(e)})
obj,_ = FailedTransactions.objects.get_or_create(service_id=project,service_name="ScriptAudit")
creator = User.objects.get(id=user_id)
obj.creator = creator
obj.transaction_type = "UploadScriptAuditData"
obj.transaction_hash = ""
obj.transaction_status = "failed"
obj.transaction_error = "Transaction failed"
obj.transaction_data = str(data)
obj.save()
return False, str(e)
return e
def getScriptAudit(private_key,user_id,project):
ACCOUNT = web3.eth.account.from_key(private_key).address

View File

@ -5,7 +5,7 @@ org_id = "org-ynvY79L4IdQHUXRlK8QZN1IU"
SECRET_KEY = 'django-insecure-l+u)264k9gmd1l9*fh9vcu6#y_oi9k%n3c533&b^7&j%&#!gr1'
DEBUG = 1
ALLOWED_HOSTS=127.0.0.1,1.6.141.108,1.6.141.104,taj.mynextfilm.in,52.66.163.18
INSTALLED_APPS=django.contrib.admin,django.contrib.auth,django.contrib.contenttypes,django.contrib.sessions,django.contrib.messages,django.contrib.staticfiles,django.contrib.sites,django_crontab,allauth,allauth.account,allauth.socialaccount,allauth.socialaccount.providers.google,users,mnfapp,auto_email,lpp,centralizePayment,centralisedFileSystem,scriptAudit,conversion,juggernaut,payment,institutional,storages,Blockchain2,telemetry
INSTALLED_APPS=django.contrib.admin,django.contrib.auth,django.contrib.contenttypes,django.contrib.sessions,django.contrib.messages,django.contrib.staticfiles,django.contrib.sites,django_crontab,allauth,allauth.account,allauth.socialaccount,allauth.socialaccount.providers.google,users,mnfapp,auto_email,lpp,centralizePayment,centralisedFileSystem,scriptAudit,conversion,juggernaut,payment,institutional,storages,Blockchain2
ENGINE='django.db.backends.postgresql_psycopg2'
DB_NAME='MNF_AWS'

View File

@ -22,8 +22,6 @@ from io import BytesIO
from auto_email.views import sendmail
from lpp.certificate.createCertificate import certificateGenrate
from scriptAudit.utils import update_audit_status
from Blockchain2.models import MNFServersFile
from django.core.files import File as File2
# from django.conf import settings
basePath = BasePath()
@ -301,14 +299,12 @@ def lpp_audit(msg):
print("blockchain script conversion 3", uploaded_script, translated_scripttt)
with open(uploaded_script, 'rb') as f:
hash = uploadDataToIPFSNode(f)
savefiles(f, uploaded_script, obj.translation_id,"original_scriptFile_hash")
scriptconversion["original_scriptFile_hash"] = hash
scriptconversion["original_scriptFile_path"] = uploaded_script
scriptconversion["date_at"] = current_datetime.strftime("%Y-%m-%d %H:%M:%S")
print("blockchain script conversion 4")
with open(translated_scripttt, 'rb') as f1:
hash = uploadDataToIPFSNode(f1)
savefiles(f1, translated_scripttt, obj.translation_id,"translated_scriptFile_hash")
scriptconversion["translated_scriptFile_hash"] = hash
scriptconversion["translated_scriptFile_path"] = translated_scripttt
print("blockchain script conversion 5")
@ -343,7 +339,6 @@ def lpp_audit(msg):
# script_size = file_to_audit_docx.file.size
with open(script_path1, 'rb') as _file:
hash2 = uploadDataToIPFSNode(_file)
savefiles(_file, script_path1, obj.translation_id,"script-json")
print(f"hash2 is ---> {hash2}")
script_json["script_file_path"] = script_path1
script_json["script_file"] = hash2
@ -519,13 +514,3 @@ class Command(BaseCommand):
break
print("Completed All Execution")
def savefiles(file, path, script_id,File_type):
filename = os.path.basename(path)
django_file = File2(file)
files, _ = MNFServersFile.objects.get_or_create(
project_id= script_id,
file_type=File_type,
)
files.public_file.save(filename, django_file)

View File

@ -422,10 +422,6 @@ class Conversion:
if obj.User_preference !="MNF":
tx_id, tx_gas_fee = UploadConversionData(OWNER_KEY, blockchain_obj.publicKey, UserId, str(Project),
Data)
if tx_id == False:
obj.User_preference = "MNF"
obj.save()
else:
print("Tx id -> ", tx_id,tx_gas_fee)
print(type(tx_id))

1
kitchen_counter/req_beta.txt Executable file → Normal file
View File

@ -119,6 +119,7 @@ numpy==1.26.3
oauthlib==3.2.2
olefile==0.47
om-transliterator==0.1.dev0
openai==1.12.0
opencv-python==4.9.0.80
opencv-python-headless==4.9.0.80
openpyxl==3.1.2

View File

@ -1 +0,0 @@
#default_app_config = "telemetry.apps.TelemetryConfig"

View File

@ -1,3 +0,0 @@
from django.contrib import admin
# Register your models here.

View File

@ -1,78 +0,0 @@
from django.apps import AppConfig
import os
import logging
import multiprocessing
from uuid import uuid4
from opentelemetry import trace, metrics
from opentelemetry._logs import set_logger_provider
from opentelemetry.sdk.resources import Resource, SERVICE_INSTANCE_ID
from opentelemetry.sdk.trace import TracerProvider
from opentelemetry.sdk.trace.export import BatchSpanProcessor
from opentelemetry.exporter.otlp.proto.grpc.trace_exporter import OTLPSpanExporter
from opentelemetry.sdk.metrics import MeterProvider
from opentelemetry.sdk.metrics.export import PeriodicExportingMetricReader
from opentelemetry.exporter.otlp.proto.grpc.metric_exporter import OTLPMetricExporter
from opentelemetry.sdk._logs import LoggerProvider, LoggingHandler
from opentelemetry.sdk._logs.export import BatchLogRecordProcessor
from opentelemetry.exporter.otlp.proto.grpc._log_exporter import OTLPLogExporter
from opentelemetry.instrumentation.django import DjangoInstrumentor
class TelemetryConfig(AppConfig):
name = "telemetry"
def ready(self):
# Resource Definition
resource = Resource.create({
"service.name": "production-kitchen",
SERVICE_INSTANCE_ID: str(uuid4()),
"worker": os.getpid(), # os.getpid() works outside Gunicorn too
})
endpoint = os.environ.get("OTEL_EXPORTER_OTLP_ENDPOINT", "http://129.159.229.69:4317")
# TRACE SETUP
if not isinstance(trace.get_tracer_provider(), TracerProvider):
tracer_provider = TracerProvider(resource=resource)
span_exporter = OTLPSpanExporter(endpoint=endpoint)
tracer_provider.add_span_processor(BatchSpanProcessor(span_exporter))
trace.set_tracer_provider(tracer_provider)
# METRIC SETUP
if not isinstance(metrics.get_meter_provider(), MeterProvider):
metric_reader = PeriodicExportingMetricReader(OTLPMetricExporter(endpoint=endpoint))
meter_provider = MeterProvider(resource=resource, metric_readers=[metric_reader])
metrics.set_meter_provider(meter_provider)
# LOGGING SETUP
# 1. Create and set the logger provider FIRST
logger_provider = LoggerProvider(resource=resource)
set_logger_provider(logger_provider) # MUST be set before using LoggingHandler
# 2. Add processor and exporter
log_exporter = OTLPLogExporter(endpoint=endpoint)
logger_provider.add_log_record_processor(BatchLogRecordProcessor(log_exporter))
# 3. Now safely create the handler (uses global logger provider)
otel_handler = LoggingHandler(level=logging.INFO)
# 4. Attach to Django and root loggers
logging.getLogger("django").addHandler(otel_handler)
logging.getLogger("django").setLevel(logging.INFO)
logging.getLogger().addHandler(otel_handler)
logging.getLogger().setLevel(logging.INFO)
from opentelemetry.instrumentation.django import DjangoInstrumentor
DjangoInstrumentor().instrument()
import sys
from .utils import PrintLogger # assuming PrintLogger is defined in telemetry/utils.py
# Redirect print() and errors to logger so they appear in SigNoz
sys.stdout = PrintLogger(logging.INFO)
sys.stderr = PrintLogger(logging.ERROR)

View File

@ -1,3 +0,0 @@
from django.db import models
# Create your models here.

View File

@ -1,3 +0,0 @@
from django.test import TestCase
# Create your tests here.

View File

@ -1,16 +0,0 @@
import logging
import sys
class PrintLogger:
def __init__(self, level=logging.INFO):
self.logger = logging.getLogger("stdout_redirect")
self.level = level
self.terminal = sys.__stdout__ # Save original stdout
def write(self, message):
message = message.strip()
if message: # avoid empty lines
self.logger.log(self.level, message)
self.terminal.write(message + '\n') # Echo to terminal
def flush(self):
self.terminal.flush()

View File

@ -1,3 +0,0 @@
from django.shortcuts import render
# Create your views here.