Compare commits
2 Commits
d7375fa7ae
...
1163d2a3f3
Author | SHA1 | Date | |
---|---|---|---|
1163d2a3f3 | |||
fcdb10a7ff |
134
src/event.rs
134
src/event.rs
@ -1,6 +1,6 @@
|
|||||||
pub trait GitlabEventExt {
|
pub trait GitlabEventExt {
|
||||||
fn project(&self) -> &Project;
|
fn project(&self) -> &Project;
|
||||||
fn r#ref(&self) -> Option<&str>;
|
fn r#ref(&self) -> &str;
|
||||||
fn user(&self) -> &str;
|
fn user(&self) -> &str;
|
||||||
fn titles(&self) -> Vec<String>;
|
fn titles(&self) -> Vec<String>;
|
||||||
}
|
}
|
||||||
@ -109,40 +109,6 @@ pub struct PipelineMergeRequest {
|
|||||||
pub title: String,
|
pub title: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(PartialEq, Debug, Deserialize)]
|
|
||||||
pub enum IssueAction {
|
|
||||||
#[serde(rename = "open")]
|
|
||||||
Opened,
|
|
||||||
#[serde(rename = "close")]
|
|
||||||
Closed,
|
|
||||||
#[serde(rename = "reopen")]
|
|
||||||
Reopened,
|
|
||||||
#[serde(rename = "update")]
|
|
||||||
Updated,
|
|
||||||
#[serde(other)]
|
|
||||||
Other,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl IssueAction {
|
|
||||||
pub fn as_str(&self) -> &str {
|
|
||||||
match self {
|
|
||||||
IssueAction::Opened => "opened",
|
|
||||||
IssueAction::Closed => "closed",
|
|
||||||
IssueAction::Reopened => "reopened",
|
|
||||||
IssueAction::Updated => "updated",
|
|
||||||
IssueAction::Other => "other",
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, Deserialize)]
|
|
||||||
pub struct IssueObjectAttributes {
|
|
||||||
id: u32,
|
|
||||||
title: String,
|
|
||||||
action: IssueAction,
|
|
||||||
url: String,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, Deserialize)]
|
#[derive(Debug, Deserialize)]
|
||||||
#[serde(tag = "object_kind")]
|
#[serde(tag = "object_kind")]
|
||||||
pub enum GitlabEvent {
|
pub enum GitlabEvent {
|
||||||
@ -182,12 +148,6 @@ pub enum GitlabEvent {
|
|||||||
commits: Vec<Commit>,
|
commits: Vec<Commit>,
|
||||||
total_commits_count: u64,
|
total_commits_count: u64,
|
||||||
},
|
},
|
||||||
#[serde(rename = "issue")]
|
|
||||||
Issue {
|
|
||||||
user: User,
|
|
||||||
project: Project,
|
|
||||||
object_attributes: IssueObjectAttributes,
|
|
||||||
},
|
|
||||||
#[serde(rename = "merge_request")]
|
#[serde(rename = "merge_request")]
|
||||||
MergeRequest {
|
MergeRequest {
|
||||||
user: User,
|
user: User,
|
||||||
@ -209,19 +169,17 @@ impl GitlabEventExt for GitlabEvent {
|
|||||||
match self {
|
match self {
|
||||||
GitlabEvent::Push { project, .. } => &project,
|
GitlabEvent::Push { project, .. } => &project,
|
||||||
GitlabEvent::TagPush { project, .. } => &project,
|
GitlabEvent::TagPush { project, .. } => &project,
|
||||||
GitlabEvent::Issue { project, .. } => project,
|
|
||||||
GitlabEvent::MergeRequest { project, .. } => &project,
|
GitlabEvent::MergeRequest { project, .. } => &project,
|
||||||
GitlabEvent::Pipeline { project, .. } => &project,
|
GitlabEvent::Pipeline { project, .. } => &project,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn r#ref(&self) -> Option<&str> {
|
fn r#ref(&self) -> &str {
|
||||||
match self {
|
match self {
|
||||||
GitlabEvent::Push { r#ref, .. } => Some(&r#ref),
|
GitlabEvent::Push { r#ref, .. } => &r#ref,
|
||||||
GitlabEvent::TagPush { r#ref, .. } => Some(&r#ref),
|
GitlabEvent::TagPush { r#ref, .. } => &r#ref,
|
||||||
GitlabEvent::Issue { .. } => None,
|
GitlabEvent::MergeRequest { object_attributes, .. } => &object_attributes.target_branch,
|
||||||
GitlabEvent::MergeRequest { object_attributes, .. } => Some(&object_attributes.target_branch),
|
GitlabEvent::Pipeline { object_attributes, .. } => &object_attributes.r#ref,
|
||||||
GitlabEvent::Pipeline { object_attributes, .. } => Some(&object_attributes.r#ref),
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -229,7 +187,6 @@ impl GitlabEventExt for GitlabEvent {
|
|||||||
match self {
|
match self {
|
||||||
GitlabEvent::Push { user_name, .. } => &user_name,
|
GitlabEvent::Push { user_name, .. } => &user_name,
|
||||||
GitlabEvent::TagPush { user_name, .. } => &user_name,
|
GitlabEvent::TagPush { user_name, .. } => &user_name,
|
||||||
GitlabEvent::Issue { user, .. } => &user.name,
|
|
||||||
GitlabEvent::MergeRequest { user, .. } => &user.name,
|
GitlabEvent::MergeRequest { user, .. } => &user.name,
|
||||||
GitlabEvent::Pipeline { user, .. } => &user.name,
|
GitlabEvent::Pipeline { user, .. } => &user.name,
|
||||||
}
|
}
|
||||||
@ -282,52 +239,31 @@ impl GitlabEventExt for GitlabEvent {
|
|||||||
let url = format!("{}/-/tags/{}", project.web_url, parse_ref(r#ref));
|
let url = format!("{}/-/tags/{}", project.web_url, parse_ref(r#ref));
|
||||||
vec![markdown_link(&title, &url)]
|
vec![markdown_link(&title, &url)]
|
||||||
}
|
}
|
||||||
GitlabEvent::Issue { object_attributes, .. } => {
|
|
||||||
if object_attributes.action != IssueAction::Other {
|
|
||||||
let title = format!(
|
|
||||||
"Issue #{} **{}**: {}",
|
|
||||||
object_attributes.id,
|
|
||||||
object_attributes.action.as_str(),
|
|
||||||
object_attributes.title
|
|
||||||
);
|
|
||||||
vec![markdown_link(&title, &object_attributes.url)]
|
|
||||||
} else {
|
|
||||||
vec![]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
GitlabEvent::MergeRequest { object_attributes, .. } => {
|
GitlabEvent::MergeRequest { object_attributes, .. } => {
|
||||||
if object_attributes.action != MergeRequestAction::Other {
|
let title = format!(
|
||||||
let title = format!(
|
"MR !{} **{}**: {}",
|
||||||
"MR !{} **{}**: {}",
|
object_attributes.iid,
|
||||||
object_attributes.iid,
|
object_attributes.action.as_str(),
|
||||||
object_attributes.action.as_str(),
|
object_attributes.title
|
||||||
object_attributes.title
|
);
|
||||||
);
|
vec![markdown_link(&title, &object_attributes.url)]
|
||||||
vec![markdown_link(&title, &object_attributes.url)]
|
|
||||||
} else {
|
|
||||||
vec![]
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
GitlabEvent::Pipeline {
|
GitlabEvent::Pipeline {
|
||||||
object_attributes,
|
object_attributes,
|
||||||
merge_request,
|
merge_request,
|
||||||
..
|
..
|
||||||
} => {
|
} => {
|
||||||
if object_attributes.status != PipelineStatus::Other {
|
let title = object_attributes
|
||||||
let title = object_attributes
|
.name
|
||||||
.name
|
.as_ref()
|
||||||
.as_ref()
|
.map(|n| n.clone())
|
||||||
.map(|n| n.clone())
|
.or(merge_request.as_ref().map(|mr| mr.title.clone()))
|
||||||
.or(merge_request.as_ref().map(|mr| mr.title.clone()))
|
.iter()
|
||||||
.iter()
|
.fold(
|
||||||
.fold(
|
format!("Pipeline **{}**", object_attributes.status.as_str()),
|
||||||
format!("Pipeline **{}**", object_attributes.status.as_str()),
|
|accum, title| format!("{}: {}", accum, title),
|
||||||
|accum, title| format!("{}: {}", accum, title),
|
);
|
||||||
);
|
vec![markdown_link(&title, &object_attributes.url)]
|
||||||
vec![markdown_link(&title, &object_attributes.url)]
|
|
||||||
} else {
|
|
||||||
vec![]
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -432,26 +368,6 @@ mod test {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
|
||||||
pub fn parse_issue_event() -> anyhow::Result<()> {
|
|
||||||
let event = load_test_data("issue-event")?;
|
|
||||||
|
|
||||||
match event {
|
|
||||||
GitlabEvent::Issue {
|
|
||||||
user,
|
|
||||||
object_attributes,
|
|
||||||
..
|
|
||||||
} => {
|
|
||||||
assert_eq!(user.name, "Administrator");
|
|
||||||
assert_eq!(object_attributes.id, 301);
|
|
||||||
assert_eq!(object_attributes.action, IssueAction::Opened);
|
|
||||||
}
|
|
||||||
_ => panic!("not an issue event"),
|
|
||||||
}
|
|
||||||
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
pub fn parse_merge_request_event() -> anyhow::Result<()> {
|
pub fn parse_merge_request_event() -> anyhow::Result<()> {
|
||||||
let event = load_test_data("merge-request-event")?;
|
let event = load_test_data("merge-request-event")?;
|
||||||
@ -486,7 +402,7 @@ mod test {
|
|||||||
assert_eq!(object_attributes.name, Some("Pipeline for branch: master".to_string()));
|
assert_eq!(object_attributes.name, Some("Pipeline for branch: master".to_string()));
|
||||||
assert_eq!(object_attributes.r#ref, "master");
|
assert_eq!(object_attributes.r#ref, "master");
|
||||||
assert_eq!(object_attributes.status, PipelineStatus::Failed);
|
assert_eq!(object_attributes.status, PipelineStatus::Failed);
|
||||||
assert_eq!(merge_request.unwrap().title, "Test");
|
assert_eq!(merge_request.title, "Test");
|
||||||
assert_eq!(user.name, "Administrator");
|
assert_eq!(user.name, "Administrator");
|
||||||
}
|
}
|
||||||
_ => panic!("not a pipeline event"),
|
_ => panic!("not a pipeline event"),
|
||||||
|
21
src/main.rs
21
src/main.rs
@ -23,6 +23,8 @@ use matrix_sdk::{
|
|||||||
use tokio::sync::mpsc;
|
use tokio::sync::mpsc;
|
||||||
use warp::Filter;
|
use warp::Filter;
|
||||||
|
|
||||||
|
use crate::event::{MergeRequestAction, PipelineStatus};
|
||||||
|
|
||||||
async fn build_sync_settings(matrix_client: &Client) -> SyncSettings {
|
async fn build_sync_settings(matrix_client: &Client) -> SyncSettings {
|
||||||
let mut settings = SyncSettings::default().timeout(Duration::from_secs(30));
|
let mut settings = SyncSettings::default().timeout(Duration::from_secs(30));
|
||||||
if let Some(token) = matrix_client.sync_token().await {
|
if let Some(token) = matrix_client.sync_token().await {
|
||||||
@ -105,18 +107,15 @@ async fn ensure_matrix_room_joined(matrix_client: &Client, room_id: &OwnedRoomOr
|
|||||||
|
|
||||||
fn build_gitlab_messages(event: &GitlabEvent) -> Vec<String> {
|
fn build_gitlab_messages(event: &GitlabEvent) -> Vec<String> {
|
||||||
let project = event.project();
|
let project = event.project();
|
||||||
let refname = event.r#ref().map(event::parse_ref);
|
let refname = event::parse_ref(event.r#ref());
|
||||||
event
|
event
|
||||||
.titles()
|
.titles()
|
||||||
.iter()
|
.iter()
|
||||||
.map(|title| {
|
.map(|title| {
|
||||||
format!(
|
format!(
|
||||||
"\\[{}\\] {}*{}* {}",
|
"\\[{}\\] `{}` *{}* {}",
|
||||||
project.path_with_namespace,
|
project.path_with_namespace,
|
||||||
refname
|
refname,
|
||||||
.as_ref()
|
|
||||||
.map(|rn| format!("`{}` ", rn))
|
|
||||||
.unwrap_or_else(|| "".to_string()),
|
|
||||||
event.user(),
|
event.user(),
|
||||||
title,
|
title,
|
||||||
)
|
)
|
||||||
@ -129,6 +128,16 @@ async fn handle_gitlab_event(
|
|||||||
room_id: &OwnedRoomOrAliasId,
|
room_id: &OwnedRoomOrAliasId,
|
||||||
matrix_client: &Client,
|
matrix_client: &Client,
|
||||||
) -> anyhow::Result<()> {
|
) -> anyhow::Result<()> {
|
||||||
|
if let GitlabEvent::MergeRequest { object_attributes, .. } = &event {
|
||||||
|
if object_attributes.action == MergeRequestAction::Other {
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
} else if let GitlabEvent::Pipeline { object_attributes, .. } = &event {
|
||||||
|
if object_attributes.status == PipelineStatus::Other {
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
let room = ensure_matrix_room_joined(matrix_client, room_id).await?;
|
let room = ensure_matrix_room_joined(matrix_client, room_id).await?;
|
||||||
for msg in build_gitlab_messages(&event) {
|
for msg in build_gitlab_messages(&event) {
|
||||||
debug!("Sending message to {}: {}", room_id, msg);
|
debug!("Sending message to {}: {}", room_id, msg);
|
||||||
|
@ -1,145 +0,0 @@
|
|||||||
{
|
|
||||||
"object_kind": "issue",
|
|
||||||
"event_type": "issue",
|
|
||||||
"user": {
|
|
||||||
"id": 1,
|
|
||||||
"name": "Administrator",
|
|
||||||
"username": "root",
|
|
||||||
"avatar_url": "http://www.gravatar.com/avatar/e64c7d89f26bd1972efa854d13d7dd61?s=40\u0026d=identicon",
|
|
||||||
"email": "admin@example.com"
|
|
||||||
},
|
|
||||||
"project": {
|
|
||||||
"id": 1,
|
|
||||||
"name":"Gitlab Test",
|
|
||||||
"description":"Aut reprehenderit ut est.",
|
|
||||||
"web_url":"http://example.com/gitlabhq/gitlab-test",
|
|
||||||
"avatar_url":null,
|
|
||||||
"git_ssh_url":"git@example.com:gitlabhq/gitlab-test.git",
|
|
||||||
"git_http_url":"http://example.com/gitlabhq/gitlab-test.git",
|
|
||||||
"namespace":"GitlabHQ",
|
|
||||||
"visibility_level":20,
|
|
||||||
"path_with_namespace":"gitlabhq/gitlab-test",
|
|
||||||
"default_branch":"master",
|
|
||||||
"ci_config_path": null,
|
|
||||||
"homepage":"http://example.com/gitlabhq/gitlab-test",
|
|
||||||
"url":"http://example.com/gitlabhq/gitlab-test.git",
|
|
||||||
"ssh_url":"git@example.com:gitlabhq/gitlab-test.git",
|
|
||||||
"http_url":"http://example.com/gitlabhq/gitlab-test.git"
|
|
||||||
},
|
|
||||||
"object_attributes": {
|
|
||||||
"id": 301,
|
|
||||||
"title": "New API: create/update/delete file",
|
|
||||||
"assignee_ids": [51],
|
|
||||||
"assignee_id": 51,
|
|
||||||
"author_id": 51,
|
|
||||||
"project_id": 14,
|
|
||||||
"created_at": "2013-12-03T17:15:43Z",
|
|
||||||
"updated_at": "2013-12-03T17:15:43Z",
|
|
||||||
"updated_by_id": 1,
|
|
||||||
"last_edited_at": null,
|
|
||||||
"last_edited_by_id": null,
|
|
||||||
"relative_position": 0,
|
|
||||||
"description": "Create new API for manipulations with repository",
|
|
||||||
"milestone_id": null,
|
|
||||||
"state_id": 1,
|
|
||||||
"confidential": false,
|
|
||||||
"discussion_locked": true,
|
|
||||||
"due_date": null,
|
|
||||||
"moved_to_id": null,
|
|
||||||
"duplicated_to_id": null,
|
|
||||||
"time_estimate": 0,
|
|
||||||
"total_time_spent": 0,
|
|
||||||
"time_change": 0,
|
|
||||||
"human_total_time_spent": null,
|
|
||||||
"human_time_estimate": null,
|
|
||||||
"human_time_change": null,
|
|
||||||
"weight": null,
|
|
||||||
"health_status": "at_risk",
|
|
||||||
"iid": 23,
|
|
||||||
"url": "http://example.com/diaspora/issues/23",
|
|
||||||
"state": "opened",
|
|
||||||
"action": "open",
|
|
||||||
"severity": "high",
|
|
||||||
"escalation_status": "triggered",
|
|
||||||
"escalation_policy": {
|
|
||||||
"id": 18,
|
|
||||||
"name": "Engineering On-call"
|
|
||||||
},
|
|
||||||
"labels": [{
|
|
||||||
"id": 206,
|
|
||||||
"title": "API",
|
|
||||||
"color": "#ffffff",
|
|
||||||
"project_id": 14,
|
|
||||||
"created_at": "2013-12-03T17:15:43Z",
|
|
||||||
"updated_at": "2013-12-03T17:15:43Z",
|
|
||||||
"template": false,
|
|
||||||
"description": "API related issues",
|
|
||||||
"type": "ProjectLabel",
|
|
||||||
"group_id": 41
|
|
||||||
}]
|
|
||||||
},
|
|
||||||
"repository": {
|
|
||||||
"name": "Gitlab Test",
|
|
||||||
"url": "http://example.com/gitlabhq/gitlab-test.git",
|
|
||||||
"description": "Aut reprehenderit ut est.",
|
|
||||||
"homepage": "http://example.com/gitlabhq/gitlab-test"
|
|
||||||
},
|
|
||||||
"assignees": [{
|
|
||||||
"name": "User1",
|
|
||||||
"username": "user1",
|
|
||||||
"avatar_url": "http://www.gravatar.com/avatar/e64c7d89f26bd1972efa854d13d7dd61?s=40\u0026d=identicon"
|
|
||||||
}],
|
|
||||||
"assignee": {
|
|
||||||
"name": "User1",
|
|
||||||
"username": "user1",
|
|
||||||
"avatar_url": "http://www.gravatar.com/avatar/e64c7d89f26bd1972efa854d13d7dd61?s=40\u0026d=identicon"
|
|
||||||
},
|
|
||||||
"labels": [{
|
|
||||||
"id": 206,
|
|
||||||
"title": "API",
|
|
||||||
"color": "#ffffff",
|
|
||||||
"project_id": 14,
|
|
||||||
"created_at": "2013-12-03T17:15:43Z",
|
|
||||||
"updated_at": "2013-12-03T17:15:43Z",
|
|
||||||
"template": false,
|
|
||||||
"description": "API related issues",
|
|
||||||
"type": "ProjectLabel",
|
|
||||||
"group_id": 41
|
|
||||||
}],
|
|
||||||
"changes": {
|
|
||||||
"updated_by_id": {
|
|
||||||
"previous": null,
|
|
||||||
"current": 1
|
|
||||||
},
|
|
||||||
"updated_at": {
|
|
||||||
"previous": "2017-09-15 16:50:55 UTC",
|
|
||||||
"current": "2017-09-15 16:52:00 UTC"
|
|
||||||
},
|
|
||||||
"labels": {
|
|
||||||
"previous": [{
|
|
||||||
"id": 206,
|
|
||||||
"title": "API",
|
|
||||||
"color": "#ffffff",
|
|
||||||
"project_id": 14,
|
|
||||||
"created_at": "2013-12-03T17:15:43Z",
|
|
||||||
"updated_at": "2013-12-03T17:15:43Z",
|
|
||||||
"template": false,
|
|
||||||
"description": "API related issues",
|
|
||||||
"type": "ProjectLabel",
|
|
||||||
"group_id": 41
|
|
||||||
}],
|
|
||||||
"current": [{
|
|
||||||
"id": 205,
|
|
||||||
"title": "Platform",
|
|
||||||
"color": "#123123",
|
|
||||||
"project_id": 14,
|
|
||||||
"created_at": "2013-12-03T17:15:43Z",
|
|
||||||
"updated_at": "2013-12-03T17:15:43Z",
|
|
||||||
"template": false,
|
|
||||||
"description": "Platform related issues",
|
|
||||||
"type": "ProjectLabel",
|
|
||||||
"group_id": 41
|
|
||||||
}]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user