From 0f8696adbba2e03f69fd88ec1a44446c5fe87cc5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Michal=20=C4=8Ciha=C5=99?= Date: Tue, 18 Aug 2020 11:09:23 +0200 Subject: [PATCH] Fix importing non owner comments Temporarily chaning ownership of the ticket allows to post comment by any customer. --- README.md | 3 --- rt2zammad.py | 16 +++++++++++----- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index 29fe7e0..e2b01d5 100644 --- a/README.md +++ b/README.md @@ -5,9 +5,6 @@ for everybody, you will probably have to customize it. Known issues: -* Comments on issues from non creators are rejected by Zammad. This can be - workarounded by creating appropriate organizations in Zammad manually or - temporarily grainting Users group agent privilege. * Disabled users from RT can not be accessed by API, thus will lack email address and will fail to be created. Enable all users prior to the migration. * Timestamps are not preserved. The Zammad API doesn't seem to allow this. diff --git a/rt2zammad.py b/rt2zammad.py index f63510a..9637f69 100755 --- a/rt2zammad.py +++ b/rt2zammad.py @@ -132,16 +132,16 @@ STATUSMAP = {"new": 1, "open": 2, "resolved": 4, "rejected": 4, "deleted": 4} USERMAP = {} for user in target.user.all(): - USERMAP[user["email"].lower()] = user["login"] + USERMAP[user["email"].lower()] = user -def get_user(userdata): +def get_user(userdata, attr="login"): email = userdata["EmailAddress"] lemail = email.lower() # Search existing users if lemail not in USERMAP: for user in target.user.search({"query": email}): - USERMAP[user["email"].lower()] = user["login"] + USERMAP[user["email"].lower()] = user # Create new one if lemail not in USERMAP: kwargs = {"email": email} @@ -157,9 +157,9 @@ def get_user(userdata): kwargs["lastname"] = last kwargs["firstname"] = first user = target.user.create(kwargs) - USERMAP[user["email"].lower()] = user["login"] + USERMAP[user["email"].lower()] = user - return USERMAP[lemail] + return USERMAP[lemail][attr] # Create tickets @@ -204,6 +204,10 @@ for ticket in tickets: "mime-type": data["ContentType"], } ) + creator_id = get_user(users[item["Creator"]], "id") + chown = creator_id != new["customer_id"] + if chown: + target.ticket.update(new["id"], {"customer_id": creator_id}) TicketArticle(get_zammad(on_behalf_of=get_user(users[item["Creator"]]))).create( { "ticket_id": new["id"], @@ -212,3 +216,5 @@ for ticket in tickets: "attachments": files, } ) + if chown: + target.ticket.update(new["id"], {"customer_id": new["customer_id"]})