logger2 / app.py
Sanjayraju30's picture
Update app.py
10cd160 verified
raw
history blame
2.16 kB
def process_image(image):
if image is None:
return "❌ No image provided", "", None, gr.update(visible=True)
try:
weight = extract_weight(image)
print("🧠 Final OCR Result:", weight)
ist = pytz.timezone('Asia/Kolkata')
timestamp = datetime.now(ist).strftime("%Y-%m-%d %H:%M:%S IST")
# Handle fallback errors
if not weight or ("No valid" in weight and "OCR:" not in weight):
return "❌ Unable to detect. Try again with a clearer image.", "", image, gr.update(visible=True)
# Extract number and unit
numeric_match = re.search(r'\d{1,5}(?:\.\d{1,3})?', weight)
if not numeric_match:
return "❌ Could not extract number", "", image, gr.update(visible=True)
numeric_value = float(numeric_match.group())
unit = "kg" if "kg" in weight.lower() else "g"
# Save image
image_path = "snapshot.jpg"
image.save(image_path)
# Create Salesforce record
record = sf.Weight_Log__c.create({
"Captured_Weight__c": numeric_value,
"Captured_Unit__c": unit,
"Captured_At__c": datetime.now(ist).isoformat(),
"Device_ID__c": "DEVICE-001",
"Status__c": "Confirmed"
})
# Upload image to Salesforce
with open(image_path, "rb") as f:
encoded_image = base64.b64encode(f.read()).decode("utf-8")
content = sf.ContentVersion.create({
"Title": f"Snapshot_{timestamp}",
"PathOnClient": "snapshot.jpg",
"VersionData": encoded_image
})
content_id = sf.query(
f"SELECT ContentDocumentId FROM ContentVersion WHERE Id = '{content['id']}'"
)['records'][0]['ContentDocumentId']
sf.ContentDocumentLink.create({
"ContentDocumentId": content_id,
"LinkedEntityId": record['id'],
"ShareType": "V",
"Visibility": "AllUsers"
})
return weight, timestamp, image, gr.update(visible=False)
except Exception as e:
return f"Error: {str(e)}", "", None, gr.update(visible=True)