Beispiel #1
0
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
Beispiel #2
0
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
Beispiel #3
0
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)
Beispiel #4
0
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)