Ejemplo n.º 1
0
Archivo: util.py Proyecto: dimagi/bhoma
def post_xform_to_couch(instance):
    """
    Post an xform to couchdb, based on the settings.XFORMS_POST_URL.
    Returns the newly created document from couchdb, or raises an
    exception if anything goes wrong
    """
    def _has_errors(response, errors):
        return errors or "error" in response
    
    # check settings for authentication credentials
    try:
        response, errors = post_from_settings(instance)
        if not _has_errors(response, errors):
            doc_id = response
            try:
                xform = CXFormInstance.get(doc_id)
                # fire signals
                feedback = xform_saved.send_robust(sender="post", form=xform)
                for func, errors in feedback:
                    if errors:
                        logging.error("Problem sending post-save signal %s for xform %s" % (func, doc_id))
                    
                xform.release_lock()
                return xform
            except Exception, e:
                logging.exception("Problem accessing form %s after post" % doc_id)
                raise
        else:
Ejemplo n.º 2
0
 def add_sha1_to_line(line):
     try:
         xform_id = line["id"]
         xform = CXFormInstance.get(xform_id)
         add_sha1(None, xform)
     except Exception:
         logging.exception("problem with sha1 callback")
Ejemplo n.º 3
0
 def add_form_to_patient(line):
     
     change = Change(line)
     
     # check the global max seq in this process to avoid repeating ourselves.
     if change.seq < max_seq:
         return log_and_abort(logging.DEBUG, "ignoring item %s because it's seq is old")
     update_max_seq(change)
         
     form_id = change.id
     # don't bother with deleted or old documents
     if change.deleted or not change.is_current(db): return 
         
     formdoc = CXFormInstance.get(form_id)
     pat_id = get_patient_id_from_form(formdoc)
     if pat_id is not None and get_classification(formdoc.namespace) == "clinic":
         try:
             # this is so we don't get conflicting updates.  
             # resolve conflicts and bump version numbers before adding forms  
             pat_data = get_db().get(pat_id, conflicts=True)
             if "_conflicts" in pat_data:
                 return log_and_abort(logging.INFO, "ignoring patient %s because there are still conflicts that need to be resolved" % pat_id)
             else:
                 pat = CPatient.wrap(pat_data)
                 if pat.requires_upgrade():
                     return log_and_abort(logging.INFO, "ignoring patient %s, form %s because it is not yet upgraded to the latest version" % (pat_id, form_id))
             found_ids = [enc.xform_id for enc in pat.encounters]
             if form_id in found_ids and not formdoc.requires_upgrade():
                 return log_and_abort(logging.DEBUG, "Already found appropriate version of form %s in patient %s, no need to do anything" % (form_id, pat_id))
             else:
                 print "Form %s not found in patient %s or was old.  Rebuilding the patient now" % (form_id, pat_id)
                 reprocess(pat_id)
         except ResourceNotFound, e:
             return log_and_abort(logging.WARNING, "tried to check form %s in patient %s but patient has been deleted.  Ignoring" % (form_id, pat_id))
Ejemplo n.º 4
0
def get_bhoma_case_id_from_pregnancy(pregnancy):
    """
    Generate a unique (but deterministic) bhoma case id from pregnancy data.
    """
    return "preg%s" % CXFormInstance.get(pregnancy.anchor_form_id).sha1