9124310f28
At the moment we cannot see weather a user left a project due to their membership expiring of if they themselves opted to leave the project. This adds a new event type that allows us to make this differentiation. Note that is not really feasable to go back and reliably fix up the previous events. As a result the events for previous expire removals will remain the same however events of this nature going forward will be correctly represented.
92 lines
2.5 KiB
Ruby
92 lines
2.5 KiB
Ruby
# EventCreateService class
|
|
#
|
|
# Used for creating events feed on dashboard after certain user action
|
|
#
|
|
# Ex.
|
|
# EventCreateService.new.new_issue(issue, current_user)
|
|
#
|
|
class EventCreateService
|
|
def open_issue(issue, current_user)
|
|
create_record_event(issue, current_user, Event::CREATED)
|
|
end
|
|
|
|
def close_issue(issue, current_user)
|
|
create_record_event(issue, current_user, Event::CLOSED)
|
|
end
|
|
|
|
def reopen_issue(issue, current_user)
|
|
create_record_event(issue, current_user, Event::REOPENED)
|
|
end
|
|
|
|
def open_mr(merge_request, current_user)
|
|
create_record_event(merge_request, current_user, Event::CREATED)
|
|
end
|
|
|
|
def close_mr(merge_request, current_user)
|
|
create_record_event(merge_request, current_user, Event::CLOSED)
|
|
end
|
|
|
|
def reopen_mr(merge_request, current_user)
|
|
create_record_event(merge_request, current_user, Event::REOPENED)
|
|
end
|
|
|
|
def merge_mr(merge_request, current_user)
|
|
create_record_event(merge_request, current_user, Event::MERGED)
|
|
end
|
|
|
|
def open_milestone(milestone, current_user)
|
|
create_record_event(milestone, current_user, Event::CREATED)
|
|
end
|
|
|
|
def close_milestone(milestone, current_user)
|
|
create_record_event(milestone, current_user, Event::CLOSED)
|
|
end
|
|
|
|
def reopen_milestone(milestone, current_user)
|
|
create_record_event(milestone, current_user, Event::REOPENED)
|
|
end
|
|
|
|
def destroy_milestone(milestone, current_user)
|
|
create_record_event(milestone, current_user, Event::DESTROYED)
|
|
end
|
|
|
|
def leave_note(note, current_user)
|
|
create_record_event(note, current_user, Event::COMMENTED)
|
|
end
|
|
|
|
def join_project(project, current_user)
|
|
create_event(project, current_user, Event::JOINED)
|
|
end
|
|
|
|
def leave_project(project, current_user)
|
|
create_event(project, current_user, Event::LEFT)
|
|
end
|
|
|
|
def expired_leave_project(project, current_user)
|
|
create_event(project, current_user, Event::EXPIRED)
|
|
end
|
|
|
|
def create_project(project, current_user)
|
|
create_event(project, current_user, Event::CREATED)
|
|
end
|
|
|
|
def push(project, current_user, push_data)
|
|
create_event(project, current_user, Event::PUSHED, data: push_data)
|
|
end
|
|
|
|
private
|
|
|
|
def create_record_event(record, current_user, status)
|
|
create_event(record.project, current_user, status, target_id: record.id, target_type: record.class.name)
|
|
end
|
|
|
|
def create_event(project, current_user, status, attributes = {})
|
|
attributes.reverse_merge!(
|
|
project: project,
|
|
action: status,
|
|
author_id: current_user.id
|
|
)
|
|
|
|
Event.create(attributes)
|
|
end
|
|
end
|