aboutsummaryrefslogtreecommitdiff
path: root/src/services/status_normalizer/status_normalizer.service.js
diff options
context:
space:
mode:
authorHenry Jameson <me@hjkos.com>2019-01-14 22:38:37 +0300
committerHenry Jameson <me@hjkos.com>2019-01-14 22:38:37 +0300
commit790fcf37d223f129640aca20c7e185a26b226cdd (patch)
treec77583e4f4f1c24eaa2da2958782d8f9fa3de147 /src/services/status_normalizer/status_normalizer.service.js
parente0fd6d12ed8e4105a5c95bf4f5b36bec4bd31183 (diff)
notifications now also undergo some parsing, hypothetically could use MastoAPI
notifications, maybe.
Diffstat (limited to 'src/services/status_normalizer/status_normalizer.service.js')
-rw-r--r--src/services/status_normalizer/status_normalizer.service.js39
1 files changed, 34 insertions, 5 deletions
diff --git a/src/services/status_normalizer/status_normalizer.service.js b/src/services/status_normalizer/status_normalizer.service.js
index 6a575bf5..0dbceaa4 100644
--- a/src/services/status_normalizer/status_normalizer.service.js
+++ b/src/services/status_normalizer/status_normalizer.service.js
@@ -23,10 +23,6 @@ const qvitterStatusType = (status) => {
return 'unknown'
}
-const isMastoAPI = (status) => {
- return status.hasOwnProperty('account')
-}
-
export const parseUser = (data) => {
const output = {}
const masto = data.hasOwnProperty('acct')
@@ -95,6 +91,7 @@ export const parseUser = (data) => {
}
const parseAttachment = (data) => {
+ // TODO A little bit messy ATM but works with both APIs
return {
...data,
mimetype: data.mimetype || data.type
@@ -103,11 +100,12 @@ const parseAttachment = (data) => {
export const parseStatus = (data) => {
const output = {}
- const masto = isMastoAPI(data)
+ const masto = data.hasOwnProperty('account')
output.raw = data
console.log(masto ? 'MAMMAL' : 'OLD SHIT')
console.log(data)
+
if (masto) {
output.favorited = data.favourited
output.fave_num = data.favourites_count
@@ -172,6 +170,37 @@ export const parseStatus = (data) => {
return output
}
+export const parseNotification = (data) => {
+ const mastoDict = {
+ 'favourite': 'like',
+ 'reblog': 'repeat'
+ }
+ const masto = !data.hasOwnProperty('ntype')
+ const output = {}
+
+ if (masto) {
+ output.type = mastoDict[data.type] || data.type
+ output.seen = null // missing
+ output.status = parseStatus(data.status)
+ output.action = null // missing
+ output.from_profile = parseUser(data.account)
+ } else {
+ const parsedNotice = parseStatus(data.notice)
+ output.type = data.ntype
+ output.seen = data.is_seen
+ output.status = output.type === 'like'
+ ? parseStatus(data.notice.favorited_status)
+ : parsedNotice
+ output.action = parsedNotice
+ output.from_profile = parseUser(data.from_profile)
+ }
+
+ output.created_at = new Date(data.created_at)
+ output.id = data.id
+
+ return output
+}
+
const isNsfw = (status) => {
const nsfwRegex = /#nsfw/i
return (status.tags || []).includes('nsfw') || !!status.text.match(nsfwRegex)