def get_moderator_group_set(node_group_set, curr_group_id, get_details=False): ''' Returns the "group_set". Takes two arguments: - node_group_set: existing/current group_set of node object. - curr_group_id: current group in which this node resides. Pass the deep copy of group_set and not the reference. e.g: updated_group_set = get_moderator_group_set(node_group_set[:], group_id) ------------ if there is need of extra information along with group_set, pass <get_details=True> as last arg. e.g: updated_group_set = get_moderator_group_set(node_group_set[:], group_id, get_details=True) Along with group_set following details will be returned in DICT format: { "updated_group_set": updated_group_set, "is_group_set_updated": is_group_set_updated, "removed_group_id": removed_group_id, "newly_appended_group_id": newly_appended_group_id, "newly_appended_group_name": newly_appended_group_name, "is_new_group_top_group": is_new_group_top_group } ''' curr_group_obj = node_collection.one({'_id': ObjectId(curr_group_id)}) group_set = node_group_set[:] is_group_set_updated = False is_new_group_top_group = False # initializing dict with defaults: details_dict = { "updated_group_set": group_set, "is_group_set_updated": is_group_set_updated, "removed_group_id": None, "newly_appended_group_id": None, "newly_appended_group_name": None, "is_new_group_top_group": is_new_group_top_group } # check if current group having edit policy of EDITABLE_MODERATED. # if no return group_set as it was if not curr_group_obj.edit_policy == 'EDITABLE_MODERATED': if get_details: return details_dict else: return node_group_set # ---| getting appropriate member_of group |--- # for top level of moderated group list_of_sg_member_of = get_sg_member_of(curr_group_obj._id) if "ModeratingGroup" in list_of_sg_member_of: member_of = node_collection.one({'_type': 'GSystemType', 'name': u'ModeratingGroup'}) elif 'ProgramEventGroup' in list_of_sg_member_of: member_of = node_collection.one({'_type': 'GSystemType', 'name': u'ProgramEventGroup'}) elif 'CourseEventGroup' in list_of_sg_member_of: member_of = node_collection.one({'_type': 'GSystemType', 'name': u'CourseEventGroup'}) # for sub-group falling under one of following categories: # elif curr_group_obj.member_of_names_list[0] in ['PartnerGroup', 'ModeratingGroup']: # member_of = node_collection.one({'_id': curr_group_obj.member_of[0]}) # final fallback option else: # GST of "ModeratingGroup" member_of = node_collection.one({'_type': 'GSystemType', 'name': u'ModeratingGroup'}) # getting sub-group having: # curr_group in prior_node # and member_of as fetched above # and moderation_level > -1 sub_mod_group_obj = node_collection.one({ '_type': 'Group', 'prior_node': {'$in': [ObjectId(curr_group_obj._id)]}, 'member_of': {'$in': [ObjectId(member_of._id)]}, 'moderation_level': {'$gt': -1} }) # print "curr_group_obj._id : ", curr_group_obj._id # print "member_of._id : ", member_of._id # print "sub_mod_group_obj.name : ", sub_mod_group_obj.name # proper sub-group found if sub_mod_group_obj: if ObjectId(curr_group_id) in group_set: # remove current group's _id removed_group_id = group_set.pop(group_set.index(ObjectId(curr_group_id))) if not ObjectId(sub_mod_group_obj._id) in group_set: # add next/sub-group's _id group_set.append(sub_mod_group_obj._id) newly_appended_group_id = sub_mod_group_obj._id.__str__() newly_appended_group_name = sub_mod_group_obj.name is_group_set_updated = True # if no sub-group found or it's last sub-group of hierarchy else: mod_group_instance = CreateModeratedGroup(request.HttpRequest()) is_top_group, top_group_obj = mod_group_instance.get_top_group_of_hierarchy(curr_group_id) # print "==== ", is_top_group # print "==== ", top_group_obj if ObjectId(curr_group_id) in group_set: # remove current group's _id removed_group_id = group_set.pop(group_set.index(ObjectId(curr_group_id))) if is_top_group and (not ObjectId(top_group_obj._id) in group_set): # add parent/top group's _id group_set.append(top_group_obj._id) newly_appended_group_id = top_group_obj._id.__str__() newly_appended_group_name = top_group_obj.name is_group_set_updated = True is_new_group_top_group = True if get_details: details_dict = { "updated_group_set": group_set, "is_group_set_updated": is_group_set_updated, "removed_group_id": removed_group_id, "newly_appended_group_id": newly_appended_group_id, "newly_appended_group_name": newly_appended_group_name, "is_new_group_top_group": is_new_group_top_group } return details_dict # print group_set return group_set
def get_moderator_group_set(node_group_set, curr_group_id, get_details=False): ''' Returns the "group_set". Takes two arguments: - node_group_set: existing/current group_set of node object. - curr_group_id: current group in which this node resides. Pass the deep copy of group_set and not the reference. e.g: updated_group_set = get_moderator_group_set(node_group_set[:], group_id) ------------ if there is need of extra information along with group_set, pass <get_details=True> as last arg. e.g: updated_group_set = get_moderator_group_set(node_group_set[:], group_id, get_details=True) Along with group_set following details will be returned in DICT format: { "updated_group_set": updated_group_set, "is_group_set_updated": is_group_set_updated, "removed_group_id": removed_group_id, "newly_appended_group_id": newly_appended_group_id, "newly_appended_group_name": newly_appended_group_name, "is_new_group_top_group": is_new_group_top_group } ''' curr_group_obj = node_collection.one({'_id': ObjectId(curr_group_id)}) group_set = node_group_set[:] is_group_set_updated = False is_new_group_top_group = False # initializing dict with defaults: details_dict = { "updated_group_set": group_set, "is_group_set_updated": is_group_set_updated, "removed_group_id": None, "newly_appended_group_id": None, "newly_appended_group_name": None, "is_new_group_top_group": is_new_group_top_group } # check if current group having edit policy of EDITABLE_MODERATED. # if no return group_set as it was if not curr_group_obj.edit_policy == 'EDITABLE_MODERATED': if get_details: return details_dict else: return node_group_set # ---| getting appropriate member_of group |--- # for top level of moderated group list_of_sg_member_of = get_sg_member_of(curr_group_obj._id) if "ModeratingGroup" in list_of_sg_member_of: member_of = node_collection.one({'_type': 'GSystemType', 'name': u'ModeratingGroup'}) elif 'ProgramEventGroup' in list_of_sg_member_of: member_of = node_collection.one({'_type': 'GSystemType', 'name': u'ProgramEventGroup'}) elif 'CourseEventGroup' in list_of_sg_member_of: member_of = node_collection.one({'_type': 'GSystemType', 'name': u'CourseEventGroup'}) # for sub-group falling under one of following categories: # elif curr_group_obj.member_of_names_list[0] in ['PartnerGroup', 'ModeratingGroup']: # member_of = node_collection.one({'_id': curr_group_obj.member_of[0]}) # final fallback option else: # GST of "ModeratingGroup" member_of = node_collection.one({'_type': 'GSystemType', 'name': u'ModeratingGroup'}) # getting sub-group having: # curr_group in prior_node # and member_of as fetched above # and moderation_level > -1 sub_mod_group_obj = node_collection.one({ '_type': 'Group', 'prior_node': {'$in': [ObjectId(curr_group_obj._id)]}, 'member_of': {'$in': [ObjectId(member_of._id)]}, 'moderation_level': {'$gt': -1} }) # print "curr_group_obj._id : ", curr_group_obj._id # print "member_of._id : ", member_of._id # print "sub_mod_group_obj.name : ", sub_mod_group_obj.name # proper sub-group found if sub_mod_group_obj: if ObjectId(curr_group_id) in group_set: # remove current group's _id removed_group_id = group_set.pop(group_set.index(ObjectId(curr_group_id))) if not ObjectId(sub_mod_group_obj._id) in group_set: # add next/sub-group's _id group_set.append(sub_mod_group_obj._id) newly_appended_group_id = sub_mod_group_obj._id.__str__() newly_appended_group_name = sub_mod_group_obj.name is_group_set_updated = True # if no sub-group found or it's last sub-group of hierarchy else: mod_group_instance = CreateModeratedGroup(request.HttpRequest()) is_top_group, top_group_obj = mod_group_instance.get_top_group_of_hierarchy(curr_group_id) # print "==== ", is_top_group # print "==== ", top_group_obj if ObjectId(curr_group_id) in group_set: # remove current group's _id removed_group_id = group_set.pop(group_set.index(ObjectId(curr_group_id))) if is_top_group and (not ObjectId(top_group_obj._id) in group_set): # add parent/top group's _id group_set.append(top_group_obj._id) newly_appended_group_id = top_group_obj._id.__str__() newly_appended_group_name = top_group_obj.name is_group_set_updated = True is_new_group_top_group = True if get_details: details_dict = { "updated_group_set": group_set, "is_group_set_updated": is_group_set_updated, "removed_group_id": removed_group_id, "newly_appended_group_id": newly_appended_group_id, "newly_appended_group_name": newly_appended_group_name, "is_new_group_top_group": is_new_group_top_group } return details_dict # print group_set return group_set
def approve_resource(request, group_id): ''' Method to approve resorce. Means resource will get published by moderator to next moderated or parent group. ''' group_obj = get_group_name_id(group_id, get_obj=True) node_id = request.POST.get('node_oid', '') node_obj = node_collection.one({'_id': ObjectId(node_id)}) approve_or_reject = request.POST.get('app_rej_state', '') flag = 0 # good to check at JS/front-end level if approve_or_reject == "Approve": if node_obj: node_group_set = node_obj.group_set # task_id = get_relation_value(node_obj._id,"has_current_approval_task") # make deep copy of object and not to copy it's reference with [:]. group_set_details_dict = get_moderator_group_set(node_group_set[:], group_id, get_details=True) updated_group_set = group_set_details_dict['updated_group_set'] # print "==== updated_group_set : ", updated_group_set # print "==== node_group_set : ", node_group_set # print "==== group_set_details_dict : ", group_set_details_dict # if set(node_group_set) != set(updated_group_set): if group_set_details_dict['is_group_set_updated']: node_obj.group_set = updated_group_set # ---| checking for top group. \ # If not top group and it's fond to be sub group create task |--- # one way: # group_obj = get_group_name_id(updated_group_set[len(updated_group_set) - 1], get_obj=True) # print "===== group_obj.member_of_names_list : ", group_obj.member_of_names_list # if group_obj.member_of_names_list[0] in ['ProgramEventGroup', 'CourseEventGroup', 'PartnerGroup', 'ModeratingGroup']: # second way: if group_set_details_dict['is_new_group_top_group']: # means, resource is passed through curation flow and \ # therefore change the status from 'MODERATION' to 'PUBLISHED' node_obj.status = u'PUBLISHED' # intimate creator of object/resource and creator of parent group node_creator_username = User.objects.get(id=node_obj.created_by).username task_content_org = u"Congratulations " + unicode(node_creator_username) + \ u",\n\n Your contribution is moderated and it's published to " + \ group_set_details_dict['newly_appended_group_name'] + \ u". \n\nWe appreciate your efforts and thank you for your contribution!" create_moderator_task(request, \ group_set_details_dict['newly_appended_group_id'],\ node_obj._id, task_type_creation='multiple', \ task_type='Other', task_content_org=task_content_org,\ created_by_name=node_creator_username) else: # resource is in curation flow hence, create a task create_moderator_task(request, \ group_set_details_dict['newly_appended_group_id'],\ node_obj._id) # node_obj.modified_by = int(request.user.id) node_obj.save(groupid=group_id) flag = 1 else: flag = 0 elif approve_or_reject == "Reject": reject_reason_msg = request.POST.get('reject_reason', '') # print "reject_reason_msg----", reject_reason_msg # raise Exception("bb") # task_node,task_rt = get_relation_value(node_obj._id,"has_current_approval_task") grel_dict = get_relation_value(node_obj._id,"has_current_approval_task") is_cursor = grel_dict.get("cursor",False) if not is_cursor: task_node = grel_dict.get("grel_node") task_rt = grel_dict.get("grel_id") auth_grp = node_collection.one({'_type': "Author", 'created_by': int(node_obj.created_by)}) node_obj.group_set = [auth_grp._id] node_obj.status = u"DRAFT" node_obj.save() # is_top_group, top_group_obj = get_top_group_of_hierarchy(group_obj._id) mod_group_instance = CreateModeratedGroup(request) # is_top_group, top_group_obj = mod_group_instance.get_top_group_of_hierarchy(curr_group_id) is_top_group, top_group_obj = mod_group_instance.get_top_group_of_hierarchy(group_obj._id) list_of_recipients_ids = [] list_of_recipients_ids.extend(group_obj.group_admin) list_of_recipients_ids.extend(top_group_obj.group_admin) list_of_recipients_ids.append(node_obj.created_by) # print list_of_recipients_ids if task_node: task_content_org = u"\n\nThis task is CLOSED.\n " \ "The resource associated with Moderation Task has been REJECTED. \n" task_dict = { "name": task_node.name, "_id" : ObjectId(task_node._id), "created_by": node_obj.created_by, "modified_by": request.user.id, "contributors": [request.user.id], "content_org": unicode(task_content_org), "created_by_name": unicode(request.user.username), "Status": u"CLOSED", "Priority": u"Normal", "Assignee": list(group_obj.group_admin[:]), # "has_type": task_type_list } task_obj = create_task(task_dict, 'group') # Sending notification to all watchers about the updates of the task try: for each_user_id in list_of_recipients_ids: activ = "Contribution to " + group_obj.name +"." mail_content = u"\n The resource "+ node_obj.name +" is REJECTED by " \ + request.user.username + ". \n" \ + "Reason specified: "+ unicode(reject_reason_msg) user_obj = User.objects.get(id=int(each_user_id)) set_notif_val(request, group_obj._id, mail_content, activ, user_obj) except Exception as e: print "\n Unable to send notifications ",e flag = 1 return HttpResponse(flag)
def approve_resource(request, group_id): ''' Method to approve resorce. Means resource will get published by moderator to next moderated or parent group. ''' group_obj = get_group_name_id(group_id, get_obj=True) node_id = request.POST.get('node_oid', '') node_obj = node_collection.one({'_id': ObjectId(node_id)}) approve_or_reject = request.POST.get('app_rej_state', '') flag = 0 # good to check at JS/front-end level if approve_or_reject == "Approve": if node_obj: node_group_set = node_obj.group_set # task_id = get_relation_value(node_obj._id,"has_current_approval_task") # make deep copy of object and not to copy it's reference with [:]. group_set_details_dict = get_moderator_group_set(node_group_set[:], group_id, get_details=True) updated_group_set = group_set_details_dict['updated_group_set'] # print "==== updated_group_set : ", updated_group_set # print "==== node_group_set : ", node_group_set # print "==== group_set_details_dict : ", group_set_details_dict # if set(node_group_set) != set(updated_group_set): if group_set_details_dict['is_group_set_updated']: node_obj.group_set = updated_group_set # ---| checking for top group. \ # If not top group and it's fond to be sub group create task |--- # one way: # group_obj = get_group_name_id(updated_group_set[len(updated_group_set) - 1], get_obj=True) # print "===== group_obj.member_of_names_list : ", group_obj.member_of_names_list # if group_obj.member_of_names_list[0] in ['ProgramEventGroup', 'CourseEventGroup', 'PartnerGroup', 'ModeratingGroup']: # second way: if group_set_details_dict['is_new_group_top_group']: # means, resource is passed through curation flow and \ # therefore change the status from 'MODERATION' to 'PUBLISHED' node_obj.status = u'PUBLISHED' # intimate creator of object/resource and creator of parent group node_creator_username = User.objects.get(id=node_obj.created_by).username task_content_org = u"Congratulations " + unicode(node_creator_username) + \ u",\n\n Your contribution is moderated and it's published to " + \ group_set_details_dict['newly_appended_group_name'] + \ u". \n\nWe appreciate your efforts and thank you for your contribution!" create_moderator_task(request, \ group_set_details_dict['newly_appended_group_id'],\ node_obj._id, task_type_creation='multiple', \ task_type='Other', task_content_org=task_content_org,\ created_by_name=node_creator_username) else: # resource is in curation flow hence, create a task create_moderator_task(request, \ group_set_details_dict['newly_appended_group_id'],\ node_obj._id) # node_obj.modified_by = int(request.user.id) node_obj.save(groupid=group_id) flag = 1 else: flag = 0 elif approve_or_reject == "Reject": reject_reason_msg = request.POST.get('reject_reason', '') # print "reject_reason_msg----", reject_reason_msg # raise Exception("bb") # task_node,task_rt = get_relation_value(node_obj._id,"has_current_approval_task") grel_dict = get_relation_value(node_obj._id,"has_current_approval_task") is_cursor = grel_dict.get("cursor",False) if not is_cursor: task_node = grel_dict.get("grel_node") task_rt = grel_dict.get("grel_id") auth_grp = node_collection.one({'_type': "Author", 'created_by': int(node_obj.created_by)}) node_obj.group_set = [auth_grp._id] node_obj.status = u"DRAFT" node_obj.save() # is_top_group, top_group_obj = get_top_group_of_hierarchy(group_obj._id) mod_group_instance = CreateModeratedGroup(request) # is_top_group, top_group_obj = mod_group_instance.get_top_group_of_hierarchy(curr_group_id) is_top_group, top_group_obj = mod_group_instance.get_top_group_of_hierarchy(group_obj._id) list_of_recipients_ids = [] list_of_recipients_ids.extend(group_obj.group_admin) list_of_recipients_ids.extend(top_group_obj.group_admin) list_of_recipients_ids.append(node_obj.created_by) # print list_of_recipients_ids if task_node: task_content_org = u"\n\nThis task is CLOSED.\n " \ "The resource associated with Moderation Task has been REJECTED. \n" task_dict = { "name": task_node.name, "_id" : ObjectId(task_node._id), "created_by": node_obj.created_by, "modified_by": request.user.id, "contributors": [request.user.id], "content_org": unicode(task_content_org), "created_by_name": unicode(request.user.username), "Status": u"CLOSED", "Priority": u"Normal", "Assignee": list(group_obj.group_admin[:]), # "has_type": task_type_list } task_obj = create_task(task_dict, 'group') # Sending notification to all watchers about the updates of the task try: for each_user_id in list_of_recipients_ids: activ = "Contribution to " + group_obj.name +"." mail_content = u"\n The resource "+ node_obj.name +" is REJECTED by " \ + request.user.username + ". \n" \ + "Reason specified: "+ unicode(reject_reason_msg) user_obj = User.objects.get(id=int(each_user_id)) set_notif_val(request, group_obj._id, mail_content, activ, user_obj) except Exception as e: print "\n Unable to send notifications ",e flag = 1 return HttpResponse(flag)