def process_property_data_before_posting(property_data, request_data, email): """ Add necessary fields to property dictionary before indexing property data, store image in full size & thumbnails format. """ custom_id = "PROP-" + cstr(int(time.time())) + '-' + cstr(random.randint(10000,99999)) property_data["property_id"] = custom_id meta_dict = add_meta_fields_before_posting(request_data) property_data.update(meta_dict) property_photo_url_dict = store_property_photos_in_propshikari(request_data.get("property_photos"),custom_id) property_data["full_size_images"] = property_photo_url_dict.get("full_size",[]) property_data["thumbnails"] = property_photo_url_dict.get("thumbnails",[]) property_data["property_photo"] = property_photo_url_dict.get("thumbnails")[0] if len(property_photo_url_dict.get("thumbnails")) else "" property_data["posted_by"] = request_data.get("user_id") property_data["user_email"] = email property_data["posting_date"] = property_data.get("posting_date") if property_data.get("posting_date") else property_data.get("creation_date") property_data["amenities"] = putil.prepare_amenities_data(property_data.get("amenities",""), property_data.get("property_type")) property_data["flat_facilities"] = putil.prepare_flat_facilities_data(property_data.get("flat_facilities",""), property_data.get("property_type")) property_data["possession_status"] = "Immediate" if property_data.get("possession") else property_data.get("possession_date") property_data["discounted_price"] = putil.get_discounted_price(property_data) if property_data.get("discount_percentage") else 0.0 mandatory_list = property_mandatory_fields.get(property_data.get("property_type")) property_data["percent_completion"] = putil.calculate_percent_completion(property_data, mandatory_list) if not property_data.get("possession_date"): property_data.pop("possession_date", None) return custom_id
def init_for_project_posting(project_data, user_email, user_id): custom_id = "PRJ-" + cstr(int(time.time())) + '-' + cstr(random.randint(10000,99999)) project_data["project_id"] = custom_id meta_dict = add_meta_fields_before_posting(project_data) project_data.update(meta_dict) project_data["posted_by"] = user_id project_data["user_email"] = user_email project_data["posting_date"] = project_data.get("posting_date") if project_data.get("posting_date") else project_data["creation_date"] project_data["amenities"] = putil.prepare_amenities_data(project_data.get("amenities",""), project_data.get("project_type")) project_data["possession_status"] = "Immediate" if project_data.get("possession") else project_data.get("possession_date") return custom_id
def process_property_data_before_posting(property_data, request_data, email): """ Add necessary fields to property dictionary before indexing property data, store image in full size & thumbnails format. """ custom_id = "PROP-" + cstr(int(time.time())) + '-' + cstr(random.randint(10000,99999)) property_data["property_id"] = custom_id meta_dict = add_meta_fields_before_posting(request_data) property_data.update(meta_dict) property_photo_url_dict = store_property_photos_in_propshikari(request_data.get("property_photos"),custom_id) property_data["full_size_images"] = property_photo_url_dict.get("full_size",[]) property_data["thumbnails"] = property_photo_url_dict.get("thumbnails",[]) property_data["property_photo"] = property_photo_url_dict.get("thumbnails")[0] if len(property_photo_url_dict.get("thumbnails")) else "" property_data["posted_by"] = request_data.get("user_id") property_data["user_email"] = email property_data["posting_date"] = property_data.get("posting_date") if property_data.get("posting_date") else property_data.get("creation_date") property_data["amenities"] = putil.prepare_amenities_data(property_data.get("amenities",""), property_data.get("property_type")) property_data["flat_facilities"] = putil.prepare_flat_facilities_data(property_data.get("flat_facilities",""), property_data.get("property_type")) property_data["possession_status"] = "Immediate" if property_data.get("possession") else property_data.get("possession_date") property_data["discounted_price"] = putil.get_discounted_price(property_data) if property_data.get("discount_percentage") else 0.0 mandatory_list = property_mandatory_fields.get(property_data.get("property_type")) property_data["percent_completion"] = putil.calculate_percent_completion(property_data, mandatory_list) # added by arpit for published_status if request_data.get("request_source") == "bulk_upload": property_data["published_status"] = "published" property_data["status"] = "Active" else: property_data["published_status"] = "Unpublished" property_data["status"] = "Deactivated" property_data["tag"] = property_data.get("tag") if property_data.get("tag") else [] # end of code if not property_data.get("possession_date"): property_data.pop("possession_date", None) return custom_id
def post_property(data): if data: try: old_data = json.loads(data) email = putil.validate_for_user_id_exists(old_data.get("user_id")) subs_doc = putil.validate_for_postings_available(email) data = putil.validate_property_posting_data(old_data,"property_json/property_mapper.json") putil.validate_property_status(data.get("status")) custom_id = "PROP-" + cstr(int(time.time())) + '-' + cstr(random.randint(10000,99999)) data["property_id"] = custom_id meta_dict = add_meta_fields_before_posting(old_data) data.update(meta_dict) # return store_property_photos_in_propshikari(old_data.get("property_photos"),custom_id) property_photo_url_dict = store_property_photos_in_propshikari(old_data.get("property_photos"),custom_id) data["full_size_images"] = property_photo_url_dict.get("full_size",[]) data["thumbnails"] = property_photo_url_dict.get("thumbnails",[]) data["property_photo"] = property_photo_url_dict.get("thumbnails")[0] if len(property_photo_url_dict.get("thumbnails")) else "" data["posted_by"] = old_data.get("user_id") data["user_email"] = email data["posting_date"] = data.get("posting_date") if data.get("posting_date") else data["creation_date"] data["amenities"] = putil.prepare_amenities_data(data.get("amenities",""), data.get("property_type")) data["flat_facilities"] = putil.prepare_flat_facilities_data(data.get("flat_facilities",""), data.get("property_type")) data["possession_status"] = "Immediate" if data.get("possession") else data.get("possession_date") data.pop("possession_date", None) es = ElasticSearchController() response_data = es.index_document("property",data, custom_id) if subs_doc and response_data.get("created"): subs_doc.posted = cint(subs_doc.posted) + 1 subs_doc.save(ignore_permissions=True) subscription = putil.get_subscriptions(email) response_msg = "Property posted successfully" if response_data.get("created",False) else "Property posting failed" return {"operation":"Create", "message":response_msg, "property_id":response_data.get("_id"), "user_id":old_data.get("user_id"),"data":{"subscriptions":subscription}} except elasticsearch.RequestError,e: raise ElasticInvalidInputFormatError(e.error) except elasticsearch.ElasticsearchException,e: raise ElasticSearchException(e.error)