Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix/homepage scoring #251

Merged
merged 14 commits into from
Dec 6, 2023
Merged

Conversation

WRadoslaw
Copy link
Contributor

Copy link

@ignazio-bovo ignazio-bovo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It looks ok, it's just the update query it's a bit complex now to read
Also to make sure:
Are we removing the trigger to updating the score in favour of a higher updating frequency?

Comment on lines 30 to 64
await em.query(`
WITH videos_with_weight AS (
SELECT
video.id as videoId,
c.id as channelId,
(ROUND((
(extract(epoch from now()) -
((
extract(epoch from video.created_at)*${joystreamTimestampWeight} +
COALESCE(extract(epoch from video.published_before_joystream), extract(epoch from video.created_at))*${ytTimestampWeight}
) / ${joystreamTimestampWeight} + ${ytTimestampWeight} as wtEpoch,
"channel"."channel_weight" as CW
FROM
"video"
INNER JOIN
"channel" ON "video"."channel_id" = "channel"."id"
${
forceUpdateAll
? ''
: `WHERE "video"."id" IN (${[...this.videosToUpdate.values()]
.map((id) => `'${id}'`)
.join(', ')})`
}
)
UPDATE
"video"
SET
"video_relevance" = ROUND(
(
(extract(epoch from now()) - wtEpoch) / ${NEWNESS_SECONDS_DIVIDER} * ${newnessWeight * -1} +
) / ${joystreamTimestampWeight} + ${ytTimestampWeight})) / ${NEWNESS_SECONDS_DIVIDER} * ${
newnessWeight * -1
} +
(views_num * ${viewsWeight}) +
(comments_count * ${commentsWeight}) +
(reactions_count * ${reactionsWeight})
) * COALESCE(CW, ${channelWeight}),
2)
FROM
weighted_timestamp
WHERE
"video".id = weighted_timestamp.id;
(reactions_count * ${reactionsWeight})) *
COALESCE(channel.channel_weight, ${channelWeight}),2)) as videoRelevance
FROM video
INNER JOIN channel ON video.channel_id = channel.id),

top_channel_score as (
SELECT
channel.id as channelId,
MAX(videoCte.videoRelevance) as maxChannelRelevance
FROM channel
INNER JOIN videos_with_weight as videoCte on videoCte.cId = channel.id
GROUP BY channel.id)

UPDATE video
SET video_relevance = COALESCE(topChannelVideo.maxScore, 1)
FROM videos_with_weight as videoCte
LEFT JOIN top_channel_score as topChannelVideo on topChannelVideo.channelId = videoCte.cId and topChannelVideo.maxScore = videoCte.videoRelevance
WHERE video.id = videoCte.vId;
`)
this.videosToUpdate.clear()
}
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you maybe break down this complex query into smaller pieces for better readability? Even with Copilot is a bit complex to decipher

Copy link
Contributor

@zeeshanakram3 zeeshanakram3 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good, I noticed that you removed the scheduleRecalcForVideo method. Although it was not used right now, I think this could have been a very useful addition if used properly. We can have two different relevance score calculation intervals, a smaller interval (e.g. 10 mins) for all the scheduled videos (i.e. scheduled due to view, comments, channel weight updates, etc.), and a larger interval for table-wide recalculation.

Since the video table is growing rapidly I think recalculation of the relevance score for all the videos every 10 minutes, is not ideal, so the relevance score update for the whole table can be every 12/24 hours.

Copy link
Contributor

@zeeshanakram3 zeeshanakram3 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good. Just a couple of points

  • Please include this change to avoid potential Postgres deadlocks (Avoiding Postgres transaction deadlocks #268 (comment))

  • What do you think about this We can have two different relevance score calculation intervals, a smaller interval (e.g. 10 mins) for all the scheduled videos (i.e. scheduled due to view, comments, channel weight updates, etc.), and a larger interval for table-wide recalculation. from my comment.

@zeeshanakram3 zeeshanakram3 self-requested a review December 5, 2023 10:10
src/utils/VideoRelevanceManager.ts Outdated Show resolved Hide resolved
WRadoslaw and others added 3 commits December 5, 2023 12:04
Co-authored-by: Zeeshan Akram <[email protected]>
# Conflicts:
#	src/mappings/utils.ts
#	src/utils/VideoRelevanceManager.ts
Copy link
Contributor

@zeeshanakram3 zeeshanakram3 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@zeeshanakram3
Copy link
Contributor

Couple of things that I missed in the review:

Would you please address these before the tomorrow's deployment. Thanks

@WRadoslaw
Copy link
Contributor Author

Couple of things that I missed in the review:

Would you please address these before the tomorrow's deployment. Thanks

  1. Ok.
  2. It's already done here, it doesn't show up, because this change is older than my PR

@ignazio-bovo ignazio-bovo merged commit c8b2c2e into Joystream:master Dec 6, 2023
7 checks passed
zeeshanakram3 added a commit that referenced this pull request Feb 27, 2024
* fix: 🐛 encoding issues with member handle (#214)

* fix: 🐛 encoding issues with member handle

* fix: 🐛 pr issues

* fix: 🐛 refactor and update changelog

* docs: update version number

* fix: 🚑 account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: ✨ add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: ✨ add CORS origins for atlas local testing

* chore: 📝 adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: ⚡ add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: ✨ changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Hotfix/3.1.0 (#240)

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: ✨ changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: 🚑 hotfix default value for channel weight no matter what

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Orion notifications final (#264)

* User accounts notifications (#164)

* feat: squash all commits for notification demo

fix: add notification and template choice

feat: sketch mutation for setting the prefeences

fix: arguments for preference selection function

feat: add runtime notification data and notification preferences

fix: notification for runtime events

fix: add notification preference mutation

feat: add email strategy

fix: split Notification into onchain and offchain

fix: add channel created event notifiation

feat: distinguisher between member and channel notifiation

feat: enable offchain notification entities export

fix: notification preferences resolver

fix: migration

feat: default notification preferences

feat: start adding tests

fix: tests

fix: tests

fix: notificatino preference mutation and complete test

fix: add support for offchain dat

fix: missc

fix: format & fix build errors

fix: build and migrations

fix: bugs in setting notifications

fix: add case for notification mutation status

fix: build errors

fix: format

fix: data

* fix: remove non needed entity for migration

export / import scripts allows to specify fields of entities which will be migrated
In this case runtime notification will be migrated partially by offchain and partiall
by handlers

* feat: mark notifications as read

* fix: runtime notification migration generation

* feat: add event notification for video posted

* feat: add video comment

* feat: add chanel verification mutation

* feat: video excluded from app notifications

* feat: channel exclusion

* fix: Channel exclusion

* feat: notification deposit for video reaction

* feat: reaction for comment notification

* feat: refactor and add channel excluded mail template

* fix: email

* feat: regenerate migrations

fix: notifications

fix: misc

* fix: WS_SOURCE for archive

* feat: boilerplate code for notification testing

fix: gql subscriptions

* ♻️ Refactor into object mother like context

* 🩹 Fix: graphql client now working

* 🐛 Logged in client able to send mutation

* ✏️ Fix: set missing notification preferences

* 🩹 Match notification pref names with design

* 🩹 Match notification pref names with design

* 🩹 Fix: SetAccountNotificationPreference resolver

* ✅ Test: Channel created notification

* ✅ Test: FolloChannel notificatino

* ♻️ Ref: notification deposit function

* ✅ Test: Video posted

* ♻️ Ref: addNotification and notification type

* feat: 🎨 create extrinsic file and add make payment to channel

* feat: 🎨 add extra extrinsic for auction notifications

* feat: 🎨 add react to video, comment to video and send payment to channel extrinsics

* refactor: ✨ refactoring code in order to account for manual tests and nft issuance tx status

* feat: 🎨 improve test by adding start auction and start offer

* docs: 📝 review auction bid notification cases and added comments

* fix: 🐛 notify creator on video comment

* fix: 💚 build error

* feat: 🎨 add notification for featured video / nft

* fix: 🐛 channel follower user id

* fix: 🐛 review notification pref parsing

* feat: 🎨 migrate Account to Account with pref (all enabled)

* feat: 🎨 migration from Channel to Channel with verification

* feat: 🎨 offchain notifcations creation timestmap

* refactor: ♻️ Notification code rework to accomodate design specs

* fix: 🎨 notification delivery and fields

* feat: 🎨 no separate notifications

* migration order

* email function rework

* notifications rework

* refactor: ♻️ unify notifications

* fix: 💚 fix notification build error after schema changes

* feat: 🚚 rename and re org utils/notification directory

* fix: 💚 mappings/content/channels tsc errors

* refactor: 💚 fix content/comments and reactions / videos

* fix: 💚 fix content / nft notification deposit

* fix: 💚 channel / resolvers notification deposit

* fix: 💚 Video resolver notification deposit

* fix: 💚 admin resolvers

* fix: 💚 fix direct member payment notification deposit

* fix: 💚 fix notification resolvers

* feat: 🎨 add app root domain

* feat: 🎨 add notification links

* feat: 🎨 notification links

* feat: 🎨 set resolver for setting app_root_domain and notification center

* feat: 🎨 add email content with some formatting

* feat: 🎨 add verify channel resolver with approporiate ChannelVerification entity

* fix: 🔥 no events or notifications are removed

no events or notifications will be removed, since they are now tied to an account and at the mement we don't support account deletion

* feat: 🎨 add royalty payment

* fix: 💚 build errors

* fix: 🩹 patch squid middleware to return 401 for unauth

* fix: 💚 fix ci build

* feat: 🎨 migrate next entity id for account

* temporarely hide integration tests

* fix gitignore

* fix: 💚 eslint fixes

* prettier

* chore: 💚 generate migration data and bump versions

* feat: add channel verification to hidden entities

* feat: 🐛 migrations

* fix: 💚 CI checks on migrations

* notifications visible to accounts

* feat: 🔥 re-establish old visibility policy for notificatinos

* fix: misc

* fix: 🐛 misc fixes for migrations

* feat: 🎨 rename auctionExpired -> timedAuctionExpired and add notificatino for channel suspended

* feat: 🎨 channel suspension resolver

* feat: ✨ better emails

* fix: 🐛 royalty computation and notification id tag

* feat: 🎨 add notification timestamp

* fix: 🐛 purchased nft / channel payment / funds withdrawn notification text

* fix: 🐛 resolvers

* fix: 🐛 VideoHero and channel suspension resolvers

* feat: 💚 fix ci build

* fix: 💚 generate Data.js and add suspension to hidden entities

* fix: 🎨 add channel_suspended to migrated entities

* style: 💄 better name for computeRoyalty args

* fix: 💚 post rebase fixes

* fix: 💚 post rebase fixes

* fix: 💚 post rebase fixes

* Update src/mappings/content/nft.ts

Co-authored-by: attemka <[email protected]>

* Update src/mappings/content/nft.ts

Co-authored-by: attemka <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/mappings/content/channel.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/mappings/content/channel.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/server-extension/resolvers/NotificationResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update package.json

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/server-extension/resolvers/VideosResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/server-extension/resolvers/ChannelsResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: 🐛 notification created only once when orion_db is active

* fix: 🎨 misc PR comment address

added non-visibility of notification_delivery_* entities

* feat: 🎨 exported state entity migrated

* fix: 🎨 remove joystream patched types

* fix: 🎨 add ypp status to better match the YTS code

* style: 💄 refactor code for page links

* fix: 🎨 setup text for notifications & regenerate schema

* fix: 🐛 PR comments

feat: ♻️ refactor mail code

fix: ⚡ royalty price precision

fix: 🐛 PR comments

perf: ⚡ add max number of concurrent promises for fetching channel followers

fix: 🐛 PR comments

fix: 🐛 PR comments

fix: 🐛 PR comments

regenerate data

Update src/mappings/content/channel.ts

Co-authored-by: Zeeshan Akram <[email protected]>

Update src/server-extension/resolvers/VideosResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

fix: 🐛 overlay vs orion_db for notification

Now notification are first written in the overlay (if deposited by processor) otherwise they are written directly into orion_db

fix: 🐛 overlay vs orion_db for notification

Now notification are first written in the overlay (if deposited by processor) otherwise they are written directly into orion_db

fix: 🐛 overlay vs orion_db for notification

Now notification are first written in the overlay (if deposited by processor) otherwise they are written directly into orion_db

fix: 🐛 separate mail sent by processor and those sent by server due to overlay presence

fix: 🐛 notification & notification on chain delivery mail deposit

fix: 🐛 notification & notification on chain delivery mail deposit

fix: 🐛 notification & notification on chain delivery mail deposit

* fix: 🐛 rework channel notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: 🐛 rework channel notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: 🐛 rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: 🐛 rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: 🐛 rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: 🐛 rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: 🐛 rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

---------

Co-authored-by: attemka <[email protected]>
Co-authored-by: Zeeshan Akram <[email protected]>

* fix: uninitialized access of NftPurchased type (#179)

* Orion notifications fixes (#195)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: 📝 update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: 🚑 fix accountId global counter not being migrated (#188)

* style: 🎨 schema & helpers refactor

feat: ✨ resolver for in app notification

* Update the recipient schema

* feat(notification v1): ✨ resolver for in-app notifications

* fix: 🎨 remove inApp delivery entity and inApp resolver no longer used

* fix: 🎨 make notification public and fix linter

* fix: 🐛 PR iter

* test: ✅ test setup missing notificationsj

* test: ✅ add test for set Featured nft

* fix: 🐛 misc fixes after testing

* added referrerChannelId to the Account entity

* fix: ✅ add all tests for missing notifications

* fix: ✅ add all tests for missing notifications

* ci: 💚 add a notifications tests

* fix: 🚨 linter fixes

* fix: 💚 regenerate typeorm-migration scripts

* fix: ✅ update bid related tests and clean test reports

* feat: 🎨 make channel excluded member notification

* feat: 🎨 make channel excluded member notification

* fix: ✨ add event data for channel

* style: 💄 remove unused variant

* fix: ✏️ re check all relation between notification preferences and entities

* fix: ✏️ re check all relation between notification preferences and entities

* fix: ✨ NotificationPreferences Object type for the graphql resolver

* fix: 🐛 distinguish between auction types

* fix: 🐛 distinguish between auction types

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>
Co-authored-by: attemka <[email protected]>

* fix: 🐛 Video Liked data unitialized (#204)

* Orion notifications video liked (#205)

* fix: 🐛 Video Liked data unitialized

* fix: 🐛 Video Liked data unitialized

* test: ✅ add test for video liked

* test: ✅ add test for video liked

* fix: comment id not added to notification data (#206)

* fix: 🐛 uninitialized notification data fields (#207)

* migrations to 3.1.0 with fix for Overlay data race during migration (#200)

* feat: 🎨 add migration for accounts and channels

* test: ✅ add network test folder

* feat: ✅ add archive dump and export to test migrations

* feat: 🐛 overlay and migration data race

* ci: 💚 add ci checks for migration

* fix: ⚰️ remove dead code

* Mail scheduler feature (#208)

* feat: ✨ start scheduler work

* test: ✅ add test setup

* feat: 🎨 review data model

* feat: 🎨 setup tests and refactor data model

* test: 🎨 add extra seed data

* feat: 🎨 EmailDelivey.status success status changed on sendNew

* feat: 🎨 report entities generated on sendNew

* feat: 🎨 add support for error status

* fix: 🐛 avoid rewriting failedDlivery field on EmailDelivery with old version

* fix: 🎨 add fk for inApp and email delivery no notification entity

* feat: 🎨 add max attempt config variable

* feat: 🎨 seed data for config variable

* fix: 🎨 refactor after rebase

* feat: ✅ start adding test boilerplate code

feat: 🎨 finalize delivery feature

feat: 💚 add ci checks with scheduler tests

fix: 🚨 fix linter

* feat: ⏪ rebase to orion_notifications

* Add an MJML template for email notifications

* Update the links

* Adjust the template after testing it

* Update email links, texts, and icons

* Add avatars in email notifications

* Format amounts of JOYs in the notifications

* Have notification nft links open the nft widget

* Point icon links to GH for now

* Fix the `formatJOY` function

* Add the missing email data

* Update the template for png icons

* Improve avatar code

* Remove unnecessary change

* feat: 🎨 config variables for email

* feat: ✨ add resolvers for setting variables

tested ✅

* feat: enable mail content and remove unused file

* fix: ✅ content delegated to Q&A

* fix: 📦 update package lock

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Notifications/scheduler main (#210)

* feat: ✨ add main function invocation

* feat: ✨ make dbgen

* fix: 🎨 process env not being read for db connection (#212)

* 👥 Add member ids to `NotificationType` (#219)

* Add memberIds to some `NotificationType`

* Link to members by ids on emails

* Get member avatars by id on emails

* update notification branch with master (#220)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: 📝 update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: 🚑 fix accountId global counter not being migrated (#188)

* docs: 📝 add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: 🎨 process env not being read for db connection

* test: 🧪 add test for email delivery entity deposit

* fix: 🐛 encoding issues with member handle (#214)

* fix: 🐛 encoding issues with member handle

* fix: 🐛 pr issues

* fix: 🐛 refactor and update changelog

* docs: update version number

* fix: 🚑 account counter (#215)

* fix: 🧪 failing test on migratinos

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* update with master (#233)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: 📝 update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: 🚑 fix accountId global counter not being migrated (#188)

* docs: 📝 add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: 🐛 encoding issues with member handle (#214)

* fix: 🐛 encoding issues with member handle

* fix: 🐛 pr issues

* fix: 🐛 refactor and update changelog

* docs: update version number

* fix: 🚑 account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: ✨ add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: ✨ add CORS origins for atlas local testing

* chore: 📝 adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: ⚡ add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>

* 🔨 Fix the notification template (#234)

* Fix notification template

* Remove `!` from the email subject

* Fix asset links

* Notification branch fixes for issued arised during Q&A (#225)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: 📝 update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: 🚑 fix accountId global counter not being migrated (#188)

* docs: 📝 add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: 🐛 encoding issues with member handle (#214)

* fix: 🐛 encoding issues with member handle

* fix: 🐛 pr issues

* fix: 🐛 refactor and update changelog

* docs: update version number

* fix: 🚑 account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: ✨ add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: ✨ add CORS origins for atlas local testing

* chore: 📝 adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* fix(notifications): uninitialized access fields

* fix(notifications): 🐛 add channelId to new auction

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: ⚡ add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: ✨ changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Hotfix/3.1.0 (#240)

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: ✨ changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: 🚑 hotfix default value for channel weight no matter what

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: ✅ add test for comment reply and metadata

* fix: ✨ solve conflicts

* test: ✅ add test for channel verification + refactoring

* chore: 🚨 linter

* fix: 💚 add 10 seconds sleep time for CI checks

* fix: 🐛 channel excluded title

* docs: 📝 typo

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>

* 🩹 Fix JOY values in emails and footer (#241)

* Fix JOY values in emails

* Fix email footer

* Test `formatJOY` function

* Use `Number.toFixed` to rewrite `formatJOY`

* Fix demo emails

* 🔧 One more notification email fix (#254)

* Attempt to fix channel avatar on emails

* Improve email template

* Notifications/qa fixes (#250)

* fix: 🐛 unitialized access video posted + misc

* feat: ⚡ batch channel verification

* fix: ⚡ remove non necessary import

* Notifications/qa fixes (#255)

* fix: 🐛 unitialized access video posted + misc

* feat: ⚡ batch channel verification

* fix: ⚡ remove non necessary import

* feat: ✨ batch suspend channel and pLimits promises

* Notifications/qa fixes (#256)

* fix: 🐛 unitialized access video posted + misc

* feat: ⚡ batch channel verification

* fix: ⚡ remove non necessary import

* feat: ✨ batch suspend channel and pLimits promises

* fix: 🐛 typegraphql return type

* Notifications/qa fixes (#255)

* fix: 🐛 unitialized access video posted + misc

* feat: ⚡ batch channel verification

* fix: ⚡ remove non necessary import

* feat: ✨ batch suspend channel and pLimits promises

* fix: 🎨 import

* style: 💄 format

* Notifications/no self notifications (#258)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: 📝 update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: 🚑 fix accountId global counter not being migrated (#188)

* docs: 📝 add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: 🐛 encoding issues with member handle (#214)

* fix: 🐛 encoding issues with member handle

* fix: 🐛 pr issues

* fix: 🐛 refactor and update changelog

* docs: update version number

* fix: 🚑 account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: ✨ add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: ✨ add CORS origins for atlas local testing

* chore: 📝 adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: ⚡ add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: ✨ changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Hotfix/3.1.0 (#240)

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: ✨ changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: 🚑 hotfix default value for channel weight no matter what

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* docs: 📝 documentation for email notificaions

* feat: 🐛 don't notify channel owner if he's reacting

* feat: 🐛 avoid sending notification for reaction to self comment

* fix: 🎨 pr comments

* fix: 💚 tests faliing on user liking his own video

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>

* 🤞 Fix the channel avatar url (#257)

* Extract the asset url logic

* Fix the channel avatar url

* Add a script to run the mail scheduler

* fix: 💚 ci error on globalem

* Memoize `getNotificationAvatar`

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* docs: 📝 changelog (#260)

* Cache avatars based on just type and id (#259)

---------

Co-authored-by: attemka <[email protected]>
Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>
Co-authored-by: omahs <[email protected]>

* fix: 🚑 remove extra return type from resolver (#265)

* Update .env

example .env updated with notification variables

* Fix/homepage scoring (#251)

* Update video relevance manager query

* Remove single video schedules for relevance recalc

* Fix namings

* Reformat query

* Revert "Remove single video schedules for relevance recalc"

This reverts commit 3a685b9

* Adjust logic for single channel recalc

* Unblock video relevance recalc only after processor reaches last exported block

* Increase global recalc interval

* Avoid query if set is empty

* Introduce smaller interval for scheduled channels

* Typo fix

Co-authored-by: Zeeshan Akram <[email protected]>

* Linter

* Add video recalc on channel weight change

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Update CHANGELOG.md

* email delivery attempt export (#271)

* Account id counter (#273)

* email delivery attempt export (#271)

* fix: 💚 remove falinig test on migration

since now we have dropped the new migration logic

* Update operator docs (#281)

* docs: 📝 improve operator example file configs

* docs: 📝 email notifications guide improvement

* fix: 📝 documentation .env archive endpoint variable

* fix: 📝 example env gateway_port:8000

* docs: rework deploy orion documentation

* docs: 📝 finalize deployment docs

* docs: 📝 minor improvements in the documentations

* Update README.md

* Extend session based on activity after initial expiry is over (#287)

* Index most used field for ordering (#246)

* Add required indexes to nft and video entity

* Regen migrations

* Add index at event timestamp field

* Regen migrations

* Regen migrations v2

* Regen migrations v3

* Fix/notification email title (#289)

* Add new property to each notification type

* Use new subject property in email

* Remove app name from subject

* Orion setup improvements (#288)

* fix: deadlock issue caused by migration scripts

* gitignore src/types/

* update nodejs version to node:18

* added 'generate-migrations' makefile  command to generate migrations

* add npm command to get graphql chema

* add opentelemetry tracing integration with graphql-server and auth-server

* update docker.yml github workflow

* fix: DistributionBucketsCache init bug

* Improved offchain import/export script

* fix: dockerfile

* fix: dockerfile

* fix eslint issues

* fix checks.yml github workflow

* regenerate db migration files

* fix: Don't expose db container ports

* fix notification errors

* merge upstream/master

* Version 3.2.1 (#290)

* fix: deadlock issue caused by migration scripts

* gitignore src/types/

* update nodejs version to node:18

* added 'generate-migrations' makefile  command to generate migrations

* add npm command to get graphql chema

* add opentelemetry tracing integration with graphql-server and auth-server

* update docker.yml github workflow

* fix: DistributionBucketsCache init bug

* Improved offchain import/export script

* fix: dockerfile

* fix: dockerfile

* fix eslint issues

* fix checks.yml github workflow

* regenerate db migration files

* fix: Don't expose db container ports

* fix notification errors

* merge upstream/master

* remove unused property 'globalCountersMigration' from OffchainState

* refactor notifications scripts

* bump package version and update changelog

* 🐉 Homepage language improvements (#295)

* Add language utils

* Add new property to schema

* Try to predict language for each video

* Generate new mappings

* 🦢 Switch language package (#296)

* Replace ngram package

* Remove fallback to metadata language

* Add language predition to the update mapping

* Changelog and version bump

* Orion db migrations and state export fixes (#298)

* read/write export.json file using big-json package

* patch @subsquid/typeorm-config & @subsquid/typeorm-migration packages to change 'squid-typeorm-migration apply' commad to apply a single migrations file too

* regenerate the postgres db migrations

* update package version and add changelog

* added custom migration to set orionLanguage to all of the processed videos

* update *-Data.js migration file

* rename *-Operator.js migrations file

* rename *-Indexes.js migrations file

* patch @subsquid/openreader and @subsquid/typeorm-codegen dependencies  include the db schema too in the generated postgres migrations, and a 'schema' directive to specify the schema of any entity

* create *-Admin.js migration to create an admin schema & user

* separate the view definitions from views migration file

* create JS script to create new views migrations file.

* add @Schema direcitve to hidden entities in graphql schema definitions

* regenerate db/migrations

* update 'generate-migrations' makefile command

* updated documentation for upgrading orion and entity visibility

* update CHANGELOG

* create VIEWs for hidden entities too

* fix: use snake case property names in createQueryBuilder instance methods

* fix: .gitignore not working

* fix lint issues

* re-generate db migrations

* Add is short field to video entity (#301)

* add isShort field to video entity

* regenerate db migrations

* remove @joystream/metadata-protobuf patch from assets/patches

* fix lint issue

* Disable both in Appp and eail notifications for video posted events (#299)

* bump package version and update CHANGELOG (#302)

* bump package version and update CHANGELOG

* change release version

* Simple public homefeed query and mutation (#304)

* update graphql schema

* add partial index on 'video.include_in_home_feed' field

* update video view definition to only include public videos

* regenerate migrations

* add dumbPublicFeedVideos custom query

* add setPublicFeedVideos mutation

* fix lint issue

* add arg to skip video IDs

* revert: update video view definition to only include public videos

* add feat. to unset public feed videos

* address requested change

* bump package version and update CHANGELOG

* commit register.html.mst file

* fix: notifications integration test

---------

Co-authored-by: Ignazio Bovo <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>
Co-authored-by: attemka <[email protected]>
zeeshanakram3 added a commit that referenced this pull request Mar 14, 2024
* Adds mappings for `ChannelAssetsDeletedByModerator` & `VideoAssetsDeletedByModerator` events (#199)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated

* Implements mappings for 'Content.VideoAssetsDeletedByModerator and 'Content.ChannelAssetsDeletedByModerator' runtime events

* remove unused import

* Nara/crt update (#244)

* feat: build orion

* feat: start generating schema

* fix: extra entities

* fixup!

* fix: continue implementing design specs

* fix: review and fix foreign key relationships

* fix: formatting

* fix: generation errors

* fix: add comment

* fix: relations

* fix: final review

* fixup!

* fix: add ending blocks

* fix: generate type & set typegen to ipv4

* fix: add support for event backward compatibility

* feat: start adding mappings

* fix: continue with mappnigs

* feat: init sale

* feat: patronage decreased to & fixed build

* feat: claim patronage event

* feat: tokens bought on amm

* feat: tokens sold on amm

* fix: add relation between sales and vesting schedules

* feat: add Tokens sold on sale vente

* feat: update upcoming sale

* feat: revenue share issued

* feat: member joined whitelist

* feat: amm deactivated

* feat: burned token

* feat: transfer policy changed to permissionless

* feat: sale finalized

* feat: finish mappings

* fix: review

* fix: remove cascade deletions

* fix: renaming & formatting

* fixup!

* fixup!

* fix: patched protobuf packages with token proto

* feat: update metadata and add event handler scheleton

* feat: token metadata

* feat: sale metadata

* fix: review comments

* fix: formatting

* fix: revenue

* Revert "fix: revenue"

This reverts commit 0821abe1e5e19be37a8d9a25d621dd148f03be9c.

* fix: token status after sale

* fix: fixmes

* fix: formatting

* fix: funds accounting during sale

* fix: amount accounting

* fix: linter

* fix: review

* fix: review 2

* fix: review

* fix: linter

* feat: migration for new db scheam

* fix: update event versions

* fix: patch types with crt_release types

* fix: patch types

* fix: generate all events versions since mainnet

* fix: temp fix after event version generation

* fix: event versioning

* fix: add migration

* fix: mignations

* fix: solve channel not being added

* fix: add id to TokenChannel

* fix: non-nullable deleted field set

* fix: format

* feat: creator token init sale re enabling

* feat: re enable sale init code

* fix: update types

* fix: amm id

* fix: id computation for revenue share

* fix: amm id computation for token

* fix: issuer transfer accounting

* fix: amm tx id

* fix: destination accounting

* feat: minor fix on holder transfer processing

* fix: re-enable metadata

* fix: metadata parsing

* fix: post reword cleanup

* fix: format

* fix: silence ci checks

* fix: event version

* fix: address PR changes

I edited all the entity that have a composite index like TokenAccount so that they have
a synthetic ID and an optionally unique @index

* fix: add hidden entities conditions

* fix: add extra fields to token in order to keep track of ongoing status

* fix: build errors

* fix: adapt mapping to new token fields

* fix: format

* feat: add trailer video entity

this is required so we can simply make trailer video hidden if video is hidden

* fix: linter

* chore: prettier

* fix: from PR review

* fix: vesting schedule schema & mappings

I have replaced the vesting schedule back to the original schema with:
- VestingSchedule: holding vesting schedule information such being amount agnostic
- VestedAccount: contains information regarded to a vested account, the goal is to mimic the
runtime logic

* fix: burning from vesting

* patch: metadata-protobuf package

* patch: metadata-protobuf package

* fix: generate migrations

* fix: purchase token on sale

* Update schema/token.graphql

Co-authored-by: Leszek Wiesner <[email protected]>

* Update schema/token.graphql

Co-authored-by: Leszek Wiesner <[email protected]>

* fix: address PR

* fix: hidden entities

* fix: migration ok

* feat: add extra check for migrations

* fix: docker network

* fix: format

* fix: remove unrequired constraint

* fix: :bug: post rebase fixes

* feat: :art: add metadata processing for issue token

* feat(crt-v1): :sparkles: chain metadata for v 2003

* fix(crt-v1): :ambulance: comment out view element for orion playgroud

* fix(crt-v1): :art: add playground config variable to .env

* feat: :white_check_mark: add tests

* fix(crt-v1): :package: packages and patches

* fix(crt-v1): :white_check_mark: update entity id used and other minor fixes

* fix(crt-v1): :white_check_mark: update entity id used and other minor fixes

* test(crt-v1): :bug: misc fixes to have tests working

* test(crt-v1): :bug: misc fixes to have tests working

* fix(crt-v1): :bug: metadata and trailer video

* feat(crt-v1): :art: update types

* fix(crt-v1): :sparkles: Add correct Ratio denomination (Permill)

* update with master

* fix: :bug: metadata not being set

* fix: :bug: parameters order

* test: :test_tube: fixing integration tests

* test(crt-v1): :test_tube: fix integration tests

* feat(crt-v1): :sparkles: last price for token and recovered field for rev share part

* feat: :sparkles: add resolver for dividend amount

* feat(crt-v1): :sparkles: start adding channel fields for trackingtotal revenue

* feat(crt-v1): :sparkles: add utils for royalty computation

* feat(crt-v1): :sparkles: cumulative revenue on channel

* feat(crt-v1): :sparkles: add resolver for transferrable amount

* fix(crt-v1): :sparkles: add `acquiredAt` to pinpoint latest vesting schedule for account

* Token metadata processing update

* Prettier

* chore(crt-v1): :zap: dbgen

* fix(crt-v1): :test_tube: fix integration tests

* fix(crt-v1): :bug: missing fields in token sale vesting source

* test(crt-v1): :test_tube: test for transferrable balance amount

* fix(crt-v1): :bug: transferrable amount

* test: :test_tube: update tests after resolver fix

* fix: :bug: error on vesting schedules array

* fix: :art: CI fixes

* docs: update gitignore

* fix: :rotating_light: prettier

* build: :pushpin: chai depnedencies

---------

Co-authored-by: Leszek Wiesner <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* Clear benefits even if not passed (#282)

* 🤑 Fix revenue share dividend estimation (#297)

* Fix on revenue share dividend estimation

* Fix type on result

* 🛕 Historical revenue share participants (#286)

* New field for revenue share

* Set potential revenue share particitants at the time of start

* Update `nara` from `master` (#307)

* fix: :bug: encoding issues with member handle (#214)

* fix: :bug: encoding issues with member handle

* fix: :bug: pr issues

* fix: :bug: refactor and update changelog

* docs: update version number

* fix: :ambulance: account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: :sparkles: add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: :sparkles: add CORS origins for atlas local testing

* chore: :memo: adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: :zap: add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Hotfix/3.1.0 (#240)

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: :ambulance: hotfix default value for channel weight no matter what

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Orion notifications final (#264)

* User accounts notifications (#164)

* feat: squash all commits for notification demo

fix: add notification and template choice

feat: sketch mutation for setting the prefeences

fix: arguments for preference selection function

feat: add runtime notification data and notification preferences

fix: notification for runtime events

fix: add notification preference mutation

feat: add email strategy

fix: split Notification into onchain and offchain

fix: add channel created event notifiation

feat: distinguisher between member and channel notifiation

feat: enable offchain notification entities export

fix: notification preferences resolver

fix: migration

feat: default notification preferences

feat: start adding tests

fix: tests

fix: tests

fix: notificatino preference mutation and complete test

fix: add support for offchain dat

fix: missc

fix: format & fix build errors

fix: build and migrations

fix: bugs in setting notifications

fix: add case for notification mutation status

fix: build errors

fix: format

fix: data

* fix: remove non needed entity for migration

export / import scripts allows to specify fields of entities which will be migrated
In this case runtime notification will be migrated partially by offchain and partiall
by handlers

* feat: mark notifications as read

* fix: runtime notification migration generation

* feat: add event notification for video posted

* feat: add video comment

* feat: add chanel verification mutation

* feat: video excluded from app notifications

* feat: channel exclusion

* fix: Channel exclusion

* feat: notification deposit for video reaction

* feat: reaction for comment notification

* feat: refactor and add channel excluded mail template

* fix: email

* feat: regenerate migrations

fix: notifications

fix: misc

* fix: WS_SOURCE for archive

* feat: boilerplate code for notification testing

fix: gql subscriptions

* :recycle: Refactor into object mother like context

* :adhesive_bandage: Fix: graphql client now working

* :bug: Logged in client able to send mutation

* :pencil2: Fix: set missing notification preferences

* :adhesive_bandage: Match notification pref names with design

* :adhesive_bandage: Match notification pref names with design

* :adhesive_bandage: Fix: SetAccountNotificationPreference resolver

* :white_check_mark: Test: Channel created notification

* :white_check_mark: Test: FolloChannel notificatino

* :recycle: Ref: notification deposit function

* :white_check_mark: Test: Video posted

* :recycle: Ref: addNotification and notification type

* feat: :art: create extrinsic file and add make payment to channel

* feat: :art: add extra extrinsic for auction notifications

* feat: :art: add react to video, comment to video and send payment to channel extrinsics

* refactor: :sparkles: refactoring code in order to account for manual tests and nft issuance tx status

* feat: :art: improve test by adding start auction and start offer

* docs: :memo: review auction bid notification cases and added comments

* fix: :bug: notify creator on video comment

* fix: :green_heart: build error

* feat: :art: add notification for featured video / nft

* fix: :bug: channel follower user id

* fix: :bug: review notification pref parsing

* feat: :art: migrate Account to Account with pref (all enabled)

* feat: :art: migration from Channel to Channel with verification

* feat: :art: offchain notifcations creation timestmap

* refactor: :recycle: Notification code rework to accomodate design specs

* fix: :art: notification delivery and fields

* feat: :art: no separate notifications

* migration order

* email function rework

* notifications rework

* refactor: :recycle: unify notifications

* fix: :green_heart: fix notification build error after schema changes

* feat: :truck: rename and re org utils/notification directory

* fix: :green_heart: mappings/content/channels tsc errors

* refactor: :green_heart: fix content/comments and reactions / videos

* fix: :green_heart: fix content / nft notification deposit

* fix: :green_heart: channel / resolvers notification deposit

* fix: :green_heart: Video resolver notification deposit

* fix: :green_heart: admin resolvers

* fix: :green_heart: fix direct member payment notification deposit

* fix: :green_heart: fix notification resolvers

* feat: :art: add app root domain

* feat: :art: add notification links

* feat: :art: notification links

* feat: :art: set resolver for setting app_root_domain and notification center

* feat: :art: add email content with some formatting

* feat: :art: add verify channel resolver with approporiate ChannelVerification entity

* fix: :fire: no events or notifications are removed

no events or notifications will be removed, since they are now tied to an account and at the mement we don't support account deletion

* feat: :art: add royalty payment

* fix: :green_heart: build errors

* fix: :adhesive_bandage: patch squid middleware to return 401 for unauth

* fix: :green_heart: fix ci build

* feat: :art: migrate next entity id for account

* temporarely hide integration tests

* fix gitignore

* fix: :green_heart: eslint fixes

* prettier

* chore: :green_heart: generate migration data and bump versions

* feat: add channel verification to hidden entities

* feat: :bug: migrations

* fix: :green_heart: CI checks on migrations

* notifications visible to accounts

* feat: :fire: re-establish old visibility policy for notificatinos

* fix: misc

* fix: :bug: misc fixes for migrations

* feat: :art: rename auctionExpired -> timedAuctionExpired and add notificatino for channel suspended

* feat: :art: channel suspension resolver

* feat: :sparkles: better emails

* fix: :bug: royalty computation and notification id tag

* feat: :art: add notification timestamp

* fix: :bug: purchased nft / channel payment / funds withdrawn notification text

* fix: :bug: resolvers

* fix: :bug: VideoHero and channel suspension resolvers

* feat: :green_heart: fix ci build

* fix: :green_heart: generate Data.js and add suspension to hidden entities

* fix: :art: add channel_suspended to migrated entities

* style: :lipstick: better name for computeRoyalty args

* fix: :green_heart: post rebase fixes

* fix: :green_heart: post rebase fixes

* fix: :green_heart: post rebase fixes

* Update src/mappings/content/nft.ts

Co-authored-by: attemka <[email protected]>

* Update src/mappings/content/nft.ts

Co-authored-by: attemka <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/mappings/content/channel.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/mappings/content/channel.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/server-extension/resolvers/NotificationResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update package.json

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/server-extension/resolvers/VideosResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/server-extension/resolvers/ChannelsResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: :bug: notification created only once when orion_db is active

* fix: :art: misc PR comment address

added non-visibility of notification_delivery_* entities

* feat: :art: exported state entity migrated

* fix: :art: remove joystream patched types

* fix: :art: add ypp status to better match the YTS code

* style: :lipstick: refactor code for page links

* fix: :art: setup text for notifications & regenerate schema

* fix: :bug: PR comments

feat: :recycle: refactor mail code

fix: :zap: royalty price precision

fix: :bug: PR comments

perf: :zap: add max number of concurrent promises for fetching channel followers

fix: :bug: PR comments

fix: :bug: PR comments

fix: :bug: PR comments

regenerate data

Update src/mappings/content/channel.ts

Co-authored-by: Zeeshan Akram <[email protected]>

Update src/server-extension/resolvers/VideosResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

fix: :bug: overlay vs orion_db for notification

Now notification are first written in the overlay (if deposited by processor) otherwise they are written directly into orion_db

fix: :bug: overlay vs orion_db for notification

Now notification are first written in the overlay (if deposited by processor) otherwise they are written directly into orion_db

fix: :bug: overlay vs orion_db for notification

Now notification are first written in the overlay (if deposited by processor) otherwise they are written directly into orion_db

fix: :bug: separate mail sent by processor and those sent by server due to overlay presence

fix: :bug: notification & notification on chain delivery mail deposit

fix: :bug: notification & notification on chain delivery mail deposit

fix: :bug: notification & notification on chain delivery mail deposit

* fix: :bug: rework channel notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework channel notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

---------

Co-authored-by: attemka <[email protected]>
Co-authored-by: Zeeshan Akram <[email protected]>

* fix: uninitialized access of NftPurchased type (#179)

* Orion notifications fixes (#195)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: :memo: update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: :ambulance: fix accountId global counter not being migrated (#188)

* style: :art: schema & helpers refactor

feat: :sparkles: resolver for in app notification

* Update the recipient schema

* feat(notification v1): :sparkles: resolver for in-app notifications

* fix: :art: remove inApp delivery entity and inApp resolver no longer used

* fix: :art: make notification public and fix linter

* fix: :bug: PR iter

* test: :white_check_mark: test setup missing notificationsj

* test: :white_check_mark: add test for set Featured nft

* fix: :bug: misc fixes after testing

* added referrerChannelId to the Account entity

* fix: :white_check_mark: add all tests for missing notifications

* fix: :white_check_mark: add all tests for missing notifications

* ci: :green_heart: add a notifications tests

* fix: :rotating_light: linter fixes

* fix: :green_heart: regenerate typeorm-migration scripts

* fix: :white_check_mark: update bid related tests and clean test reports

* feat: :art: make channel excluded member notification

* feat: :art: make channel excluded member notification

* fix: :sparkles: add event data for channel

* style: :lipstick: remove unused variant

* fix: :pencil2: re check all relation between notification preferences and entities

* fix: :pencil2: re check all relation between notification preferences and entities

* fix: :sparkles: NotificationPreferences Object type for the graphql resolver

* fix: :bug: distinguish between auction types

* fix: :bug: distinguish between auction types

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>
Co-authored-by: attemka <[email protected]>

* fix: :bug: Video Liked data unitialized (#204)

* Orion notifications video liked (#205)

* fix: :bug: Video Liked data unitialized

* fix: :bug: Video Liked data unitialized

* test: :white_check_mark: add test for video liked

* test: :white_check_mark: add test for video liked

* fix: comment id not added to notification data (#206)

* fix: :bug: uninitialized notification data fields (#207)

* migrations to 3.1.0 with fix for Overlay data race during migration (#200)

* feat: :art: add migration for accounts and channels

* test: :white_check_mark: add network test folder

* feat: :white_check_mark: add archive dump and export to test migrations

* feat: :bug: overlay and migration data race

* ci: :green_heart: add ci checks for migration

* fix: :coffin: remove dead code

* Mail scheduler feature (#208)

* feat: :sparkles: start scheduler work

* test: :white_check_mark: add test setup

* feat: :art: review data model

* feat: :art: setup tests and refactor data model

* test: :art: add extra seed data

* feat: :art: EmailDelivey.status success status changed on sendNew

* feat: :art: report entities generated on sendNew

* feat: :art: add support for error status

* fix: :bug: avoid rewriting failedDlivery field on EmailDelivery with old version

* fix: :art: add fk for inApp and email delivery no notification entity

* feat: :art: add max attempt config variable

* feat: :art: seed data for config variable

* fix: :art: refactor after rebase

* feat: :white_check_mark: start adding test boilerplate code

feat: :art: finalize delivery feature

feat: :green_heart: add ci checks with scheduler tests

fix: :rotating_light: fix linter

* feat: :rewind: rebase to orion_notifications

* Add an MJML template for email notifications

* Update the links

* Adjust the template after testing it

* Update email links, texts, and icons

* Add avatars in email notifications

* Format amounts of JOYs in the notifications

* Have notification nft links open the nft widget

* Point icon links to GH for now

* Fix the `formatJOY` function

* Add the missing email data

* Update the template for png icons

* Improve avatar code

* Remove unnecessary change

* feat: :art: config variables for email

* feat: :sparkles: add resolvers for setting variables

tested ✅

* feat: enable mail content and remove unused file

* fix: :white_check_mark: content delegated to Q&A

* fix: :package: update package lock

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Notifications/scheduler main (#210)

* feat: :sparkles: add main function invocation

* feat: :sparkles: make dbgen

* fix: :art: process env not being read for db connection (#212)

* 👥 Add member ids to `NotificationType` (#219)

* Add memberIds to some `NotificationType`

* Link to members by ids on emails

* Get member avatars by id on emails

* update notification branch with master (#220)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: :memo: update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: :ambulance: fix accountId global counter not being migrated (#188)

* docs: :memo: add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: :art: process env not being read for db connection

* test: :test_tube: add test for email delivery entity deposit

* fix: :bug: encoding issues with member handle (#214)

* fix: :bug: encoding issues with member handle

* fix: :bug: pr issues

* fix: :bug: refactor and update changelog

* docs: update version number

* fix: :ambulance: account counter (#215)

* fix: :test_tube: failing test on migratinos

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* update with master (#233)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: :memo: update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: :ambulance: fix accountId global counter not being migrated (#188)

* docs: :memo: add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: :bug: encoding issues with member handle (#214)

* fix: :bug: encoding issues with member handle

* fix: :bug: pr issues

* fix: :bug: refactor and update changelog

* docs: update version number

* fix: :ambulance: account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: :sparkles: add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: :sparkles: add CORS origins for atlas local testing

* chore: :memo: adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: :zap: add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>

* 🔨 Fix the notification template (#234)

* Fix notification template

* Remove `!` from the email subject

* Fix asset links

* Notification branch fixes for issued arised during Q&A (#225)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: :memo: update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: :ambulance: fix accountId global counter not being migrated (#188)

* docs: :memo: add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: :bug: encoding issues with member handle (#214)

* fix: :bug: encoding issues with member handle

* fix: :bug: pr issues

* fix: :bug: refactor and update changelog

* docs: update version number

* fix: :ambulance: account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: :sparkles: add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: :sparkles: add CORS origins for atlas local testing

* chore: :memo: adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* fix(notifications): uninitialized access fields

* fix(notifications): :bug: add channelId to new auction

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: :zap: add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Hotfix/3.1.0 (#240)

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: :ambulance: hotfix default value for channel weight no matter what

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: :white_check_mark: add test for comment reply and metadata

* fix: :sparkles: solve conflicts

* test: :white_check_mark: add test for channel verification + refactoring

* chore: :rotating_light: linter

* fix: :green_heart: add 10 seconds sleep time for CI checks

* fix: :bug: channel excluded title

* docs: :memo: typo

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>

* 🩹 Fix JOY values in emails and footer (#241)

* Fix JOY values in emails

* Fix email footer

* Test `formatJOY` function

* Use `Number.toFixed` to rewrite `formatJOY`

* Fix demo emails

* 🔧 One more notification email fix (#254)

* Attempt to fix channel avatar on emails

* Improve email template

* Notifications/qa fixes (#250)

* fix: :bug: unitialized access video posted + misc

* feat: :zap: batch channel verification

* fix: :zap: remove non necessary import

* Notifications/qa fixes (#255)

* fix: :bug: unitialized access video posted + misc

* feat: :zap: batch channel verification

* fix: :zap: remove non necessary import

* feat: :sparkles: batch suspend channel and pLimits promises

* Notifications/qa fixes (#256)

* fix: :bug: unitialized access video posted + misc

* feat: :zap: batch channel verification

* fix: :zap: remove non necessary import

* feat: :sparkles: batch suspend channel and pLimits promises

* fix: :bug: typegraphql return type

* Notifications/qa fixes (#255)

* fix: :bug: unitialized access video posted + misc

* feat: :zap: batch channel verification

* fix: :zap: remove non necessary import

* feat: :sparkles: batch suspend channel and pLimits promises

* fix: :art: import

* style: :lipstick: format

* Notifications/no self notifications (#258)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: :memo: update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: :ambulance: fix accountId global counter not being migrated (#188)

* docs: :memo: add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: :bug: encoding issues with member handle (#214)

* fix: :bug: encoding issues with member handle

* fix: :bug: pr issues

* fix: :bug: refactor and update changelog

* docs: update version number

* fix: :ambulance: account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: :sparkles: add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: :sparkles: add CORS origins for atlas local testing

* chore: :memo: adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: :zap: add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Hotfix/3.1.0 (#240)

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: :ambulance: hotfix default value for channel weight no matter what

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* docs: :memo: documentation for email notificaions

* feat: :bug: don't notify channel owner if he's reacting

* feat: :bug: avoid sending notification for reaction to self comment

* fix: :art: pr comments

* fix: :green_heart: tests faliing on user liking his own video

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>

* 🤞 Fix the channel avatar url (#257)

* Extract the asset url logic

* Fix the channel avatar url

* Add a script to run the mail scheduler

* fix: :green_heart: ci error on globalem

* Memoize `getNotificationAvatar`

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* docs: :memo: changelog (#260)

* Cache avatars based on just type and id (#259)

---------

Co-authored-by: attemka <[email protected]>
Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>
Co-authored-by: omahs <[email protected]>

* fix: :ambulance: remove extra return type from resolver (#265)

* Update .env

example .env updated with notification variables

* Fix/homepage scoring (#251)

* Update video relevance manager query

* Remove single video schedules for relevance recalc

* Fix namings

* Reformat query

* Revert "Remove single video schedules for relevance recalc"

This reverts commit 3a685b97

* Adjust logic for single channel recalc

* Unblock video relevance recalc only after processor reaches last exported block

* Increase global recalc interval

* Avoid query if set is empty

* Introduce smaller interval for scheduled channels

* Typo fix

Co-authored-by: Zeeshan Akram <[email protected]>

* Linter

* Add video recalc on channel weight change

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Update CHANGELOG.md

* email delivery attempt export (#271)

* Account id counter (#273)

* email delivery attempt export (#271)

* fix: :green_heart: remove falinig test on migration

since now we have dropped the new migration logic

* Update operator docs (#281)

* docs: :memo: improve operator example file configs

* docs: :memo: email notifications guide improvement

* fix: :memo: documentation .env archive endpoint variable

* fix: :memo: example env gateway_port:8000

* docs: rework deploy orion documentation

* docs: :memo: finalize deployment docs

* docs: :memo: minor improvements in the documentations

* Update README.md

* Extend session based on activity after initial expiry is over (#287)

* Index most used field for ordering (#246)

* Add required indexes to nft and video entity

* Regen migrations

* Add index at event timestamp field

* Regen migrations

* Regen migrations v2

* Regen migrations v3

* Fix/notification email title (#289)

* Add new property to each notification type

* Use new subject property in email

* Remove app name from subject

* Orion setup improvements (#288)

* fix: deadlock issue caused by migration scripts

* gitignore src/types/

* update nodejs version to node:18

* added 'generate-migrations' makefile  command to generate migrations

* add npm command to get graphql chema

* add opentelemetry tracing integration with graphql-server and auth-server

* update docker.yml github workflow

* fix: DistributionBucketsCache init bug

* Improved offchain import/export script

* fix: dockerfile

* fix: dockerfile

* fix eslint issues

* fix checks.yml github workflow

* regenerate db migration files

* fix: Don't expose db container ports

* fix notification errors

* merge upstream/master

* Version 3.2.1 (#290)

* fix: deadlock issue caused by migration scripts

* gitignore src/types/

* update nodejs version to node:18

* added 'generate-migrations' makefile  command to generate migrations

* add npm command to get graphql chema

* add opentelemetry tracing integration with graphql-server and auth-server

* update docker.yml github workflow

* fix: DistributionBucketsCache init bug

* Improved offchain import/export script

* fix: dockerfile

* fix: dockerfile

* fix eslint issues

* fix checks.yml github workflow

* regenerate db migration files

* fix: Don't expose db container ports

* fix notification errors

* merge upstream/master

* remove unused property 'globalCountersMigration' from OffchainState

* refactor notifications scripts

* bump package version and update changelog

* 🐉 Homepage language improvements (#295)

* Add language utils

* Add new property to schema

* Try to predict language for each video

* Generate new mappings

* 🦢 Switch language package (#296)

* Replace ngram package

* Remove fallback to metadata language

* Add language predition to the update mapping

* Changelog and version bump

* Orion db migrations and state export fixes (#298)

* read/write export.json file using big-json package

* patch @subsquid/typeorm-config & @subsquid/typeorm-migration packages to change 'squid-typeorm-migration apply' commad to apply a single migrations file too

* regenerate the postgres db migrations

* update package version and add changelog

* added custom migration to set orionLanguage to all of the processed videos

* update *-Data.js migration file

* rename *-Operator.js migrations file

* rename *-Indexes.js migrations file

* patch @subsquid/openreader and @subsquid/typeorm-codegen dependencies  include the db schema too in the generated postgres migrations, and a 'schema' directive to specify the schema of any entity

* create *-Admin.js migration to create an admin schema & user

* separate the view definitions from views migration file

* create JS script to create new views migrations file.

* add @schema direcitve to hidden entities in graphql schema definitions

* regenerate db/migrations

* update 'generate-migrations' makefile command

* updated documentation for upgrading orion and entity visibility

* update CHANGELOG

* create VIEWs for hidden entities too

* fix: use snake case property names in createQueryBuilder instance methods

* fix: .gitignore not working

* fix lint issues

* re-generate db migrations

* Add is short field to video entity (#301)

* add isShort field to video entity

* regenerate db migrations

* remove @joystream/metadata-protobuf patch from assets/patches

* fix lint issue

* Disable both in Appp and eail notifications for video posted events (#299)

* bump package version and update CHANGELOG (#302)

* bump package version and update CHANGELOG

* change release version

* Simple public homefeed query and mutation (#304)

* update graphql schema

* add partial index on 'video.include_in_home_feed' field

* update video view definition to only include public videos

* regenerate migrations

* add dumbPublicFeedVideos custom query

* add setPublicFeedVideos mutation

* fix lint issue

* add arg to skip video IDs

* revert: update video view definition to only include public videos

* add feat. to unset public feed videos

* address requested change

* bump package version and update CHANGELOG

* commit register.html.mst file

* fix: notifications integration test

---------

Co-authored-by: Ignazio Bovo <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>
Co-authored-by: attemka <[email protected]>

* 🦿 CRT marketplace changes (#285)

* Add new field and index to creator token

* Add mutation to feature crts

* Schema typo fix

* Add is short field to video entity (#301)

* add isShort field to video entity

* regenerate db migrations

* remove @joystream/metadata-protobuf patch from assets/patches

* fix lint issue

* Disable both in Appp and eail notifications for video posted events (#299)

* bump package version and update CHANGELOG (#302)

* bump package version and update CHANGELOG

* change release version

* Simple public homefeed query and mutation (#304)

* update graphql schema

* add partial index on 'video.include_in_home_feed' field

* update video view definition to only include public videos

* regenerate migrations

* add dumbPublicFeedVideos custom query

* add setPublicFeedVideos mutation

* fix lint issue

* add arg to skip video IDs

* revert: update video view definition to only include public videos

* add feat. to unset public feed videos

* address requested change

* bump package version and update CHANGELOG

* Update `nara` from `master` (#300)

* Adds mappings for `ChannelAssetsDeletedByModerator` & `VideoAssetsDeletedByModerator` events (#199)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated

* Implements mappings for 'Content.VideoAssetsDeletedByModerator and 'Content.ChannelAssetsDeletedByModerator' runtime events

* remove unused import

* Nara/crt update (#244)

* feat: build orion

* feat: start generating schema

* fix: extra entities

* fixup!

* fix: continue implementing design specs

* fix: review and fix foreign key relationships

* fix: formatting

* fix: generation errors

* fix: add comment

* fix: relations

* fix: final review

* fixup!

* fix: add ending blocks

* fix: generate type & set typegen to ipv4

* fix: add support for event backward compatibility

* feat: start adding mappings

* fix: continue with mappnigs

* feat: init sale

* feat: patronage decreased to & fixed build

* feat: claim patronage event

* feat: tokens bought on amm

* feat: tokens sold on amm

* fix: add relation between sales and vesting schedules

* feat: add Tokens sold on sale vente

* feat: update upcoming sale

* feat: revenue share issued

* feat: member joined whitelist

* feat: amm deactivated

* feat: burned token

* feat: transfer policy changed to permissionless

* feat: sale finalized

* feat: finish mappings

* fix: review

* fix: remove cascade deletions

* fix: renaming & formatting

* fixup!

* fixup!

* fix: patched protobuf packages with token proto

* feat: update metadata and add event handler scheleton

* feat: token metadata

* feat: sale metadata

* fix: review comments

* fix: formatting

* fix: revenue

* Revert "fix: revenue"

This reverts commit 0821abe1e5e19be37a8d9a25d621dd148f03be9c.

* fix: token status after sale

* fix: fixmes

* fix: formatting

* fix: funds accounting during sale

* fix: amount accounting

* fix: linter

* fix: review

* fix: review 2

* fix: review

* fix: linter

* feat: migration for new db scheam

* fix: update event versions

* fix: patch types with crt_release types

* fix: patch types

* fix: generate all events versions since mainnet

* fix: temp fix after event version generation

* fix: event versioning

* fix: add migration

* fix: mignations

* fix: solve channel not being added

* fix: add id to TokenChannel

* fix: non-nullable deleted field set

* fix: format

* feat: creator token init sale re enabling

* feat: re enable sale init code

* fix: update types

* fix: amm id

* fix: id computation for revenue share

* fix: amm id computation for token

* fix: issuer transfer accounting

* fix: amm tx id

* fix: destination accounting

* feat: minor fix on holder transfer processing

* fix: re-enable metadata

* fix: metadata parsing

* fix: post reword cleanup

* fix: format

* fix: silence ci checks

* fix: event version

* fix: address PR changes

I edited all the entity that have a composite index like TokenAccount so that they have
a synthetic ID and an optionally unique @index

* fix: add hidden entities conditions

* fix: add extra fields to token in order to keep track of ongoing status

* fix: build errors

* fix: adapt mapping to new token fields

* fix: format

* feat: add trailer video entity

this is required so we can simply make trailer video hidden if video is hidden

* fix: linter

* chore: prettier

* fix: from PR review

* fix: vesting schedule schema & mappings

I have replaced the vesting schedule back to the original schema with:
- VestingSchedule: holding vesting schedule information such being amount agnostic
- VestedAccount: contains information regarded to a vested account, the goal is to mimic the
runtime logic

* fix: burning from vesting

* patch: metadata-protobuf package

* patch: metadata-protobuf package

* fix: generate migrations

* fix: purchase token on sale

* Update schema/token.graphql

Co-authored-by: Leszek Wiesner <[email protected]>

* Update schema/token.graphql

Co-authored-by: Leszek Wiesner <[email protected]>

* fix: address PR

* fix: hidden entities

* fix: migration ok

* feat: add extra check for migrations

* fix: docker network

* fix: format

* fix: remove unrequired constraint

* fix: :bug: post rebase fixes

* feat: :art: add metadata processing for issue token

* feat(crt-v1): :sparkles: chain metadata for v 2003

* fix(crt-v1): :ambulance: comment out view element for orion playgroud

* fix(crt-v1): :art: add playground config variable to .env

* feat: :white_check_mark: add tests

* fix(crt-v1): :package: packages and patches

* fix(crt-v1): :white_check_mark: update entity id used and other minor fixes

* fix(crt-v1): :white_check_mark: update entity id used and other minor fixes

* test(crt-v1): :bug: misc fixes to have tests working

* test(crt-v1): :bug: misc fixes to have tests working

* fix(crt-v1): :bug: metadata and trailer video

* feat(crt-v1): :art: update types

* fix(crt-v1): :sparkles: Add correct Ratio denomination (Permill)

* update with master

* fix: :bug: metadata not being set

* fix: :bug: parameters order

* test: :test_tube: fixing integration tests

* test(crt-v1): :test_tube: fix integration tests

* feat(crt-v1): :sparkles: last price for token and recovered field for rev share part

* feat: :sparkles: add resolver for dividend amount

* feat(crt-v1): :sparkles: start adding channel fields for trackingtotal revenue

* feat(crt-v1): :sparkles: add utils for royalty computation

* feat(crt-v1): :sparkles: cumulative revenue on channel

* feat(crt-v1): :sparkles: add resolver for transferrable amount

* fix(crt-v1): :sparkles: add `acquiredAt` to pinpoint latest vesting schedule for account

* Token metadata processing update

* Prettier

* chore(crt-v1): :zap: dbgen

* fix(crt-v1): :test_tube: fix integration tests

* fix(crt-v1): :bug: missing fields in token sale vesting source

* test(crt-v1): :test_tube: test for transferrable balance amount

* fix(crt-v1): :bug: transferrable amount

* test: :test_tube: update tests after resolver fix

* fix: :bug: error on vesting schedules array

* fix: :art: CI fixes

* docs: update gitignore

* fix: :rotating_light: prettier

* build: :pushpin: chai depnedencies

---------

Co-authored-by: Leszek Wiesner <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* Clear benefits even if not passed (#282)

* 🤑 Fix revenue share dividend estimation (#297)

* Fix on revenue share dividend estimation

* Fix type on result

* 🛕 Historical revenue share participants (#286)

* New field for revenue share

* Set potential revenue share particitants at the time of start

* fix: .gitignore not working

* fix lint issues

* re-generate db migrations

* commit register.html.mst file

* fix: notifications integration test

---------

Co-authored-by: Ignazio Bovo <[email protected]>
Co-authored-by: Leszek Wiesner <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* Revert "Update `nara` from `master` (#300)" (#306)

This reverts commit 887427c75548417dedc741f9b258f7d49e1a0b4e.

* generate auth api docs and types

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: Ignazio Bovo <[email protected]>
Co-authored-by: Leszek Wiesner <[email protected]>
Co-authored-by: Zeeshan Akram <[email protected]>

* fix :re-generate migrations & set CreatorToken.isFeatured default value (#308)

* Feat/crt notifications (#267)

* User accounts notifications (#164)

* feat: squash all commits for notification demo

fix: add notification and template choice

feat: sketch mutation for setting the prefeences

fix: arguments for preference selection function

feat: add runtime notification data and notification preferences

fix: notification for runtime events

fix: add notification preference mutation

feat: add email strategy

fix: split Notification into onchain and offchain

fix: add channel created event notifiation

feat: distinguisher between member and channel notifiation

feat: enable offchain notification entities export

fix: notification preferences resolver

fix: migration

feat: default notification preferences

feat: start adding tests

fix: tests

fix: tests

fix: notificatino preference mutation and complete test

fix: add support for offchain dat

fix: missc

fix: format & fix build errors

fix: build and migrations

fix: bugs in setting notifications

fix: add case for notification mutation status

fix: build errors

fix: format

fix: data

* fix: remove non needed entity for migration

export / import scripts allows to specify fields of entities which will be migrated
In this case runtime notification will be migrated partially by offchain and partiall
by handlers

* feat: mark notifications as read

* fix: runtime notification migration generation

* feat: add event notification for video posted

* feat: add video comment

* feat: add chanel verification mutation

* feat: video excluded from app notifications

* feat: channel exclusion

* fix: Channel exclusion

* feat: notification deposit for video reaction

* feat: reaction for comment notifi…
malchililj pushed a commit to malchililj/orion that referenced this pull request Sep 3, 2024
* Update video relevance manager query

* Remove single video schedules for relevance recalc

* Fix namings

* Reformat query

* Revert "Remove single video schedules for relevance recalc"

This reverts commit 3a685b9

* Adjust logic for single channel recalc

* Unblock video relevance recalc only after processor reaches last exported block

* Increase global recalc interval

* Avoid query if set is empty

* Introduce smaller interval for scheduled channels

* Typo fix

Co-authored-by: Zeeshan Akram <[email protected]>

* Linter

* Add video recalc on channel weight change

---------

Co-authored-by: Zeeshan Akram <[email protected]>
malchililj added a commit to malchililj/orion that referenced this pull request Sep 3, 2024
* Adds mappings for `ChannelAssetsDeletedByModerator` & `VideoAssetsDeletedByModerator` events (#199)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated

* Implements mappings for 'Content.VideoAssetsDeletedByModerator and 'Content.ChannelAssetsDeletedByModerator' runtime events

* remove unused import

* Nara/crt update (#244)

* feat: build orion

* feat: start generating schema

* fix: extra entities

* fixup!

* fix: continue implementing design specs

* fix: review and fix foreign key relationships

* fix: formatting

* fix: generation errors

* fix: add comment

* fix: relations

* fix: final review

* fixup!

* fix: add ending blocks

* fix: generate type & set typegen to ipv4

* fix: add support for event backward compatibility

* feat: start adding mappings

* fix: continue with mappnigs

* feat: init sale

* feat: patronage decreased to & fixed build

* feat: claim patronage event

* feat: tokens bought on amm

* feat: tokens sold on amm

* fix: add relation between sales and vesting schedules

* feat: add Tokens sold on sale vente

* feat: update upcoming sale

* feat: revenue share issued

* feat: member joined whitelist

* feat: amm deactivated

* feat: burned token

* feat: transfer policy changed to permissionless

* feat: sale finalized

* feat: finish mappings

* fix: review

* fix: remove cascade deletions

* fix: renaming & formatting

* fixup!

* fixup!

* fix: patched protobuf packages with token proto

* feat: update metadata and add event handler scheleton

* feat: token metadata

* feat: sale metadata

* fix: review comments

* fix: formatting

* fix: revenue

* Revert "fix: revenue"

This reverts commit 0821abe1e5e19be37a8d9a25d621dd148f03be9c.

* fix: token status after sale

* fix: fixmes

* fix: formatting

* fix: funds accounting during sale

* fix: amount accounting

* fix: linter

* fix: review

* fix: review 2

* fix: review

* fix: linter

* feat: migration for new db scheam

* fix: update event versions

* fix: patch types with crt_release types

* fix: patch types

* fix: generate all events versions since mainnet

* fix: temp fix after event version generation

* fix: event versioning

* fix: add migration

* fix: mignations

* fix: solve channel not being added

* fix: add id to TokenChannel

* fix: non-nullable deleted field set

* fix: format

* feat: creator token init sale re enabling

* feat: re enable sale init code

* fix: update types

* fix: amm id

* fix: id computation for revenue share

* fix: amm id computation for token

* fix: issuer transfer accounting

* fix: amm tx id

* fix: destination accounting

* feat: minor fix on holder transfer processing

* fix: re-enable metadata

* fix: metadata parsing

* fix: post reword cleanup

* fix: format

* fix: silence ci checks

* fix: event version

* fix: address PR changes

I edited all the entity that have a composite index like TokenAccount so that they have
a synthetic ID and an optionally unique @index

* fix: add hidden entities conditions

* fix: add extra fields to token in order to keep track of ongoing status

* fix: build errors

* fix: adapt mapping to new token fields

* fix: format

* feat: add trailer video entity

this is required so we can simply make trailer video hidden if video is hidden

* fix: linter

* chore: prettier

* fix: from PR review

* fix: vesting schedule schema & mappings

I have replaced the vesting schedule back to the original schema with:
- VestingSchedule: holding vesting schedule information such being amount agnostic
- VestedAccount: contains information regarded to a vested account, the goal is to mimic the
runtime logic

* fix: burning from vesting

* patch: metadata-protobuf package

* patch: metadata-protobuf package

* fix: generate migrations

* fix: purchase token on sale

* Update schema/token.graphql

Co-authored-by: Leszek Wiesner <[email protected]>

* Update schema/token.graphql

Co-authored-by: Leszek Wiesner <[email protected]>

* fix: address PR

* fix: hidden entities

* fix: migration ok

* feat: add extra check for migrations

* fix: docker network

* fix: format

* fix: remove unrequired constraint

* fix: :bug: post rebase fixes

* feat: :art: add metadata processing for issue token

* feat(crt-v1): :sparkles: chain metadata for v 2003

* fix(crt-v1): :ambulance: comment out view element for orion playgroud

* fix(crt-v1): :art: add playground config variable to .env

* feat: :white_check_mark: add tests

* fix(crt-v1): :package: packages and patches

* fix(crt-v1): :white_check_mark: update entity id used and other minor fixes

* fix(crt-v1): :white_check_mark: update entity id used and other minor fixes

* test(crt-v1): :bug: misc fixes to have tests working

* test(crt-v1): :bug: misc fixes to have tests working

* fix(crt-v1): :bug: metadata and trailer video

* feat(crt-v1): :art: update types

* fix(crt-v1): :sparkles: Add correct Ratio denomination (Permill)

* update with master

* fix: :bug: metadata not being set

* fix: :bug: parameters order

* test: :test_tube: fixing integration tests

* test(crt-v1): :test_tube: fix integration tests

* feat(crt-v1): :sparkles: last price for token and recovered field for rev share part

* feat: :sparkles: add resolver for dividend amount

* feat(crt-v1): :sparkles: start adding channel fields for trackingtotal revenue

* feat(crt-v1): :sparkles: add utils for royalty computation

* feat(crt-v1): :sparkles: cumulative revenue on channel

* feat(crt-v1): :sparkles: add resolver for transferrable amount

* fix(crt-v1): :sparkles: add `acquiredAt` to pinpoint latest vesting schedule for account

* Token metadata processing update

* Prettier

* chore(crt-v1): :zap: dbgen

* fix(crt-v1): :test_tube: fix integration tests

* fix(crt-v1): :bug: missing fields in token sale vesting source

* test(crt-v1): :test_tube: test for transferrable balance amount

* fix(crt-v1): :bug: transferrable amount

* test: :test_tube: update tests after resolver fix

* fix: :bug: error on vesting schedules array

* fix: :art: CI fixes

* docs: update gitignore

* fix: :rotating_light: prettier

* build: :pushpin: chai depnedencies

---------

Co-authored-by: Leszek Wiesner <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* Clear benefits even if not passed (#282)

* 🤑 Fix revenue share dividend estimation (#297)

* Fix on revenue share dividend estimation

* Fix type on result

* 🛕 Historical revenue share participants (#286)

* New field for revenue share

* Set potential revenue share particitants at the time of start

* Update `nara` from `master` (#307)

* fix: :bug: encoding issues with member handle (#214)

* fix: :bug: encoding issues with member handle

* fix: :bug: pr issues

* fix: :bug: refactor and update changelog

* docs: update version number

* fix: :ambulance: account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: :sparkles: add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: :sparkles: add CORS origins for atlas local testing

* chore: :memo: adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: :zap: add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Hotfix/3.1.0 (#240)

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: :ambulance: hotfix default value for channel weight no matter what

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Orion notifications final (#264)

* User accounts notifications (#164)

* feat: squash all commits for notification demo

fix: add notification and template choice

feat: sketch mutation for setting the prefeences

fix: arguments for preference selection function

feat: add runtime notification data and notification preferences

fix: notification for runtime events

fix: add notification preference mutation

feat: add email strategy

fix: split Notification into onchain and offchain

fix: add channel created event notifiation

feat: distinguisher between member and channel notifiation

feat: enable offchain notification entities export

fix: notification preferences resolver

fix: migration

feat: default notification preferences

feat: start adding tests

fix: tests

fix: tests

fix: notificatino preference mutation and complete test

fix: add support for offchain dat

fix: missc

fix: format & fix build errors

fix: build and migrations

fix: bugs in setting notifications

fix: add case for notification mutation status

fix: build errors

fix: format

fix: data

* fix: remove non needed entity for migration

export / import scripts allows to specify fields of entities which will be migrated
In this case runtime notification will be migrated partially by offchain and partiall
by handlers

* feat: mark notifications as read

* fix: runtime notification migration generation

* feat: add event notification for video posted

* feat: add video comment

* feat: add chanel verification mutation

* feat: video excluded from app notifications

* feat: channel exclusion

* fix: Channel exclusion

* feat: notification deposit for video reaction

* feat: reaction for comment notification

* feat: refactor and add channel excluded mail template

* fix: email

* feat: regenerate migrations

fix: notifications

fix: misc

* fix: WS_SOURCE for archive

* feat: boilerplate code for notification testing

fix: gql subscriptions

* :recycle: Refactor into object mother like context

* :adhesive_bandage: Fix: graphql client now working

* :bug: Logged in client able to send mutation

* :pencil2: Fix: set missing notification preferences

* :adhesive_bandage: Match notification pref names with design

* :adhesive_bandage: Match notification pref names with design

* :adhesive_bandage: Fix: SetAccountNotificationPreference resolver

* :white_check_mark: Test: Channel created notification

* :white_check_mark: Test: FolloChannel notificatino

* :recycle: Ref: notification deposit function

* :white_check_mark: Test: Video posted

* :recycle: Ref: addNotification and notification type

* feat: :art: create extrinsic file and add make payment to channel

* feat: :art: add extra extrinsic for auction notifications

* feat: :art: add react to video, comment to video and send payment to channel extrinsics

* refactor: :sparkles: refactoring code in order to account for manual tests and nft issuance tx status

* feat: :art: improve test by adding start auction and start offer

* docs: :memo: review auction bid notification cases and added comments

* fix: :bug: notify creator on video comment

* fix: :green_heart: build error

* feat: :art: add notification for featured video / nft

* fix: :bug: channel follower user id

* fix: :bug: review notification pref parsing

* feat: :art: migrate Account to Account with pref (all enabled)

* feat: :art: migration from Channel to Channel with verification

* feat: :art: offchain notifcations creation timestmap

* refactor: :recycle: Notification code rework to accomodate design specs

* fix: :art: notification delivery and fields

* feat: :art: no separate notifications

* migration order

* email function rework

* notifications rework

* refactor: :recycle: unify notifications

* fix: :green_heart: fix notification build error after schema changes

* feat: :truck: rename and re org utils/notification directory

* fix: :green_heart: mappings/content/channels tsc errors

* refactor: :green_heart: fix content/comments and reactions / videos

* fix: :green_heart: fix content / nft notification deposit

* fix: :green_heart: channel / resolvers notification deposit

* fix: :green_heart: Video resolver notification deposit

* fix: :green_heart: admin resolvers

* fix: :green_heart: fix direct member payment notification deposit

* fix: :green_heart: fix notification resolvers

* feat: :art: add app root domain

* feat: :art: add notification links

* feat: :art: notification links

* feat: :art: set resolver for setting app_root_domain and notification center

* feat: :art: add email content with some formatting

* feat: :art: add verify channel resolver with approporiate ChannelVerification entity

* fix: :fire: no events or notifications are removed

no events or notifications will be removed, since they are now tied to an account and at the mement we don't support account deletion

* feat: :art: add royalty payment

* fix: :green_heart: build errors

* fix: :adhesive_bandage: patch squid middleware to return 401 for unauth

* fix: :green_heart: fix ci build

* feat: :art: migrate next entity id for account

* temporarely hide integration tests

* fix gitignore

* fix: :green_heart: eslint fixes

* prettier

* chore: :green_heart: generate migration data and bump versions

* feat: add channel verification to hidden entities

* feat: :bug: migrations

* fix: :green_heart: CI checks on migrations

* notifications visible to accounts

* feat: :fire: re-establish old visibility policy for notificatinos

* fix: misc

* fix: :bug: misc fixes for migrations

* feat: :art: rename auctionExpired -> timedAuctionExpired and add notificatino for channel suspended

* feat: :art: channel suspension resolver

* feat: :sparkles: better emails

* fix: :bug: royalty computation and notification id tag

* feat: :art: add notification timestamp

* fix: :bug: purchased nft / channel payment / funds withdrawn notification text

* fix: :bug: resolvers

* fix: :bug: VideoHero and channel suspension resolvers

* feat: :green_heart: fix ci build

* fix: :green_heart: generate Data.js and add suspension to hidden entities

* fix: :art: add channel_suspended to migrated entities

* style: :lipstick: better name for computeRoyalty args

* fix: :green_heart: post rebase fixes

* fix: :green_heart: post rebase fixes

* fix: :green_heart: post rebase fixes

* Update src/mappings/content/nft.ts

Co-authored-by: attemka <[email protected]>

* Update src/mappings/content/nft.ts

Co-authored-by: attemka <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/mappings/content/channel.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/mappings/content/channel.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/server-extension/resolvers/NotificationResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update package.json

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/server-extension/resolvers/VideosResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update src/server-extension/resolvers/ChannelsResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

* Update schema/hidden.graphql

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: :bug: notification created only once when orion_db is active

* fix: :art: misc PR comment address

added non-visibility of notification_delivery_* entities

* feat: :art: exported state entity migrated

* fix: :art: remove joystream patched types

* fix: :art: add ypp status to better match the YTS code

* style: :lipstick: refactor code for page links

* fix: :art: setup text for notifications & regenerate schema

* fix: :bug: PR comments

feat: :recycle: refactor mail code

fix: :zap: royalty price precision

fix: :bug: PR comments

perf: :zap: add max number of concurrent promises for fetching channel followers

fix: :bug: PR comments

fix: :bug: PR comments

fix: :bug: PR comments

regenerate data

Update src/mappings/content/channel.ts

Co-authored-by: Zeeshan Akram <[email protected]>

Update src/server-extension/resolvers/VideosResolver/index.ts

Co-authored-by: Zeeshan Akram <[email protected]>

fix: :bug: overlay vs orion_db for notification

Now notification are first written in the overlay (if deposited by processor) otherwise they are written directly into orion_db

fix: :bug: overlay vs orion_db for notification

Now notification are first written in the overlay (if deposited by processor) otherwise they are written directly into orion_db

fix: :bug: overlay vs orion_db for notification

Now notification are first written in the overlay (if deposited by processor) otherwise they are written directly into orion_db

fix: :bug: separate mail sent by processor and those sent by server due to overlay presence

fix: :bug: notification & notification on chain delivery mail deposit

fix: :bug: notification & notification on chain delivery mail deposit

fix: :bug: notification & notification on chain delivery mail deposit

* fix: :bug: rework channel notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework channel notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

* fix: :bug: rework notification data

edit notifications link and text after rework #2

review addNotifications and start fixing channel

comments and Reaction fixes

fix metadata

fix video mappings

fix utils

fix: nft mappings

fix: admin resolvers

fix: video resolvers

fix channel resolvers

---------

Co-authored-by: attemka <[email protected]>
Co-authored-by: Zeeshan Akram <[email protected]>

* fix: uninitialized access of NftPurchased type (#179)

* Orion notifications fixes (#195)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: :memo: update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: :ambulance: fix accountId global counter not being migrated (#188)

* style: :art: schema & helpers refactor

feat: :sparkles: resolver for in app notification

* Update the recipient schema

* feat(notification v1): :sparkles: resolver for in-app notifications

* fix: :art: remove inApp delivery entity and inApp resolver no longer used

* fix: :art: make notification public and fix linter

* fix: :bug: PR iter

* test: :white_check_mark: test setup missing notificationsj

* test: :white_check_mark: add test for set Featured nft

* fix: :bug: misc fixes after testing

* added referrerChannelId to the Account entity

* fix: :white_check_mark: add all tests for missing notifications

* fix: :white_check_mark: add all tests for missing notifications

* ci: :green_heart: add a notifications tests

* fix: :rotating_light: linter fixes

* fix: :green_heart: regenerate typeorm-migration scripts

* fix: :white_check_mark: update bid related tests and clean test reports

* feat: :art: make channel excluded member notification

* feat: :art: make channel excluded member notification

* fix: :sparkles: add event data for channel

* style: :lipstick: remove unused variant

* fix: :pencil2: re check all relation between notification preferences and entities

* fix: :pencil2: re check all relation between notification preferences and entities

* fix: :sparkles: NotificationPreferences Object type for the graphql resolver

* fix: :bug: distinguish between auction types

* fix: :bug: distinguish between auction types

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>
Co-authored-by: attemka <[email protected]>

* fix: :bug: Video Liked data unitialized (#204)

* Orion notifications video liked (#205)

* fix: :bug: Video Liked data unitialized

* fix: :bug: Video Liked data unitialized

* test: :white_check_mark: add test for video liked

* test: :white_check_mark: add test for video liked

* fix: comment id not added to notification data (#206)

* fix: :bug: uninitialized notification data fields (#207)

* migrations to 3.1.0 with fix for Overlay data race during migration (#200)

* feat: :art: add migration for accounts and channels

* test: :white_check_mark: add network test folder

* feat: :white_check_mark: add archive dump and export to test migrations

* feat: :bug: overlay and migration data race

* ci: :green_heart: add ci checks for migration

* fix: :coffin: remove dead code

* Mail scheduler feature (#208)

* feat: :sparkles: start scheduler work

* test: :white_check_mark: add test setup

* feat: :art: review data model

* feat: :art: setup tests and refactor data model

* test: :art: add extra seed data

* feat: :art: EmailDelivey.status success status changed on sendNew

* feat: :art: report entities generated on sendNew

* feat: :art: add support for error status

* fix: :bug: avoid rewriting failedDlivery field on EmailDelivery with old version

* fix: :art: add fk for inApp and email delivery no notification entity

* feat: :art: add max attempt config variable

* feat: :art: seed data for config variable

* fix: :art: refactor after rebase

* feat: :white_check_mark: start adding test boilerplate code

feat: :art: finalize delivery feature

feat: :green_heart: add ci checks with scheduler tests

fix: :rotating_light: fix linter

* feat: :rewind: rebase to orion_notifications

* Add an MJML template for email notifications

* Update the links

* Adjust the template after testing it

* Update email links, texts, and icons

* Add avatars in email notifications

* Format amounts of JOYs in the notifications

* Have notification nft links open the nft widget

* Point icon links to GH for now

* Fix the `formatJOY` function

* Add the missing email data

* Update the template for png icons

* Improve avatar code

* Remove unnecessary change

* feat: :art: config variables for email

* feat: :sparkles: add resolvers for setting variables

tested ✅

* feat: enable mail content and remove unused file

* fix: :white_check_mark: content delegated to Q&A

* fix: :package: update package lock

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Notifications/scheduler main (#210)

* feat: :sparkles: add main function invocation

* feat: :sparkles: make dbgen

* fix: :art: process env not being read for db connection (#212)

* 👥 Add member ids to `NotificationType` (#219)

* Add memberIds to some `NotificationType`

* Link to members by ids on emails

* Get member avatars by id on emails

* update notification branch with master (#220)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: :memo: update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: :ambulance: fix accountId global counter not being migrated (#188)

* docs: :memo: add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: :art: process env not being read for db connection

* test: :test_tube: add test for email delivery entity deposit

* fix: :bug: encoding issues with member handle (#214)

* fix: :bug: encoding issues with member handle

* fix: :bug: pr issues

* fix: :bug: refactor and update changelog

* docs: update version number

* fix: :ambulance: account counter (#215)

* fix: :test_tube: failing test on migratinos

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* update with master (#233)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: :memo: update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: :ambulance: fix accountId global counter not being migrated (#188)

* docs: :memo: add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: :bug: encoding issues with member handle (#214)

* fix: :bug: encoding issues with member handle

* fix: :bug: pr issues

* fix: :bug: refactor and update changelog

* docs: update version number

* fix: :ambulance: account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: :sparkles: add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: :sparkles: add CORS origins for atlas local testing

* chore: :memo: adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: :zap: add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>

* 🔨 Fix the notification template (#234)

* Fix notification template

* Remove `!` from the email subject

* Fix asset links

* Notification branch fixes for issued arised during Q&A (#225)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: :memo: update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: :ambulance: fix accountId global counter not being migrated (#188)

* docs: :memo: add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: :bug: encoding issues with member handle (#214)

* fix: :bug: encoding issues with member handle

* fix: :bug: pr issues

* fix: :bug: refactor and update changelog

* docs: update version number

* fix: :ambulance: account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: :sparkles: add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: :sparkles: add CORS origins for atlas local testing

* chore: :memo: adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* fix(notifications): uninitialized access fields

* fix(notifications): :bug: add channelId to new auction

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: :zap: add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Hotfix/3.1.0 (#240)

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: :ambulance: hotfix default value for channel weight no matter what

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: :white_check_mark: add test for comment reply and metadata

* fix: :sparkles: solve conflicts

* test: :white_check_mark: add test for channel verification + refactoring

* chore: :rotating_light: linter

* fix: :green_heart: add 10 seconds sleep time for CI checks

* fix: :bug: channel excluded title

* docs: :memo: typo

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>

* 🩹 Fix JOY values in emails and footer (#241)

* Fix JOY values in emails

* Fix email footer

* Test `formatJOY` function

* Use `Number.toFixed` to rewrite `formatJOY`

* Fix demo emails

* 🔧 One more notification email fix (#254)

* Attempt to fix channel avatar on emails

* Improve email template

* Notifications/qa fixes (#250)

* fix: :bug: unitialized access video posted + misc

* feat: :zap: batch channel verification

* fix: :zap: remove non necessary import

* Notifications/qa fixes (#255)

* fix: :bug: unitialized access video posted + misc

* feat: :zap: batch channel verification

* fix: :zap: remove non necessary import

* feat: :sparkles: batch suspend channel and pLimits promises

* Notifications/qa fixes (#256)

* fix: :bug: unitialized access video posted + misc

* feat: :zap: batch channel verification

* fix: :zap: remove non necessary import

* feat: :sparkles: batch suspend channel and pLimits promises

* fix: :bug: typegraphql return type

* Notifications/qa fixes (#255)

* fix: :bug: unitialized access video posted + misc

* feat: :zap: batch channel verification

* fix: :zap: remove non necessary import

* feat: :sparkles: batch suspend channel and pLimits promises

* fix: :art: import

* style: :lipstick: format

* Notifications/no self notifications (#258)

* Update squid.yaml

fix: squid.yml version numbering

* Release PR: Orion v3.0.1 (#185)

* fix: processor's overlay bug (#170)

* atlas homepage query speed optimisation (#177)

* fix: gitignored src/model/generated

* add index on video.video_relevance field

* fix typo in developer guide docs

* regenerate db/migrations/*-Data.js file

* Fix/unblock graphql (#183)

* Make session optional and apply changes for auth handles

* Create new middleware for users and use it on some resolvers

* Remove remaining auth guards

* Small docs change

* Add middleware for channel report

* Prettier

* docs: :memo: update changelog (#184)

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* fix: :ambulance: fix accountId global counter not being migrated (#188)

* docs: :memo: add back up guide (#196)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated (#193)

* fix: :bug: encoding issues with member handle (#214)

* fix: :bug: encoding issues with member handle

* fix: :bug: pr issues

* fix: :bug: refactor and update changelog

* docs: update version number

* fix: :ambulance: account counter (#215)

* Orion v3.0.3 (#224)

* Remove n+1 problem for StorageDataObject (#209)

* Remove n+1 problem for StorageDataObject

* Inform user about incorrect query

* fix: :sparkles: add global counter migratino to account for 303 (#217)

* Orion 303 final touches (#223)

* feat: :sparkles: add CORS origins for atlas local testing

* chore: :memo: adds 303 release notes

* Fix typos (#176)

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typo

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

* fix typos

---------

Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>

* Orion v3.0.4 - Release (#230)

* 🧮 Aggregate channel payments (#222)

* Fix channels `cumulativeRewardClaimed_DESC` order

* Aggregate channel payments

* Make `cumulativeRewardClaimed` and `cumulativeRewardPaid` non null

* Generate db migrations

* Rename the `cumulativeReward` field

* Re-generate db migrations

* Bump Orion's version

* feat: :zap: add migration to version 3.0.4 for account id counter (#228)

---------

Co-authored-by: Theophile Sandoz <[email protected]>

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Hotfix/3.1.0 (#240)

* Orion v3.1.0 (#238)

* Add granular permissions support for Gateway operator users (#231)

* Add granular permissions support for Gateway operator users

* fix lint issues

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* Set Channel Weight (`setChannelsWeights`) mutation (#232)

* Add granular permissions support for Gateway operator users

* fix lint issues

* add mutation to set channel weight/bias for homepage video relevance

* revert docker-compose port change

* mark 'grantPermissions' & 'revokePermissions' input fields are non-nullable & return new permissions instead of boolean

* bump package version

* update global migration counter map

* bumped package version & updated CHANGELOG

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* Postgres performance improvements (#235)

* add index in video.createdAt field

* add pg_stat_extenstion extenstion for queries stats

* docs: :sparkles: changelog and fix data-js (#237)

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* fix: :ambulance: hotfix default value for channel weight no matter what

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* docs: :memo: documentation for email notificaions

* feat: :bug: don't notify channel owner if he's reacting

* feat: :bug: avoid sending notification for reaction to self comment

* fix: :art: pr comments

* fix: :green_heart: tests faliing on user liking his own video

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>

* 🤞 Fix the channel avatar url (#257)

* Extract the asset url logic

* Fix the channel avatar url

* Add a script to run the mail scheduler

* fix: :green_heart: ci error on globalem

* Memoize `getNotificationAvatar`

---------

Co-authored-by: Ignazio Bovo <[email protected]>

* docs: :memo: changelog (#260)

* Cache avatars based on just type and id (#259)

---------

Co-authored-by: attemka <[email protected]>
Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>
Co-authored-by: omahs <[email protected]>

* fix: :ambulance: remove extra return type from resolver (#265)

* Update .env

example .env updated with notification variables

* Fix/homepage scoring (#251)

* Update video relevance manager query

* Remove single video schedules for relevance recalc

* Fix namings

* Reformat query

* Revert "Remove single video schedules for relevance recalc"

This reverts commit 3a685b97

* Adjust logic for single channel recalc

* Unblock video relevance recalc only after processor reaches last exported block

* Increase global recalc interval

* Avoid query if set is empty

* Introduce smaller interval for scheduled channels

* Typo fix

Co-authored-by: Zeeshan Akram <[email protected]>

* Linter

* Add video recalc on channel weight change

---------

Co-authored-by: Zeeshan Akram <[email protected]>

* Update CHANGELOG.md

* email delivery attempt export (#271)

* Account id counter (#273)

* email delivery attempt export (#271)

* fix: :green_heart: remove falinig test on migration

since now we have dropped the new migration logic

* Update operator docs (#281)

* docs: :memo: improve operator example file configs

* docs: :memo: email notifications guide improvement

* fix: :memo: documentation .env archive endpoint variable

* fix: :memo: example env gateway_port:8000

* docs: rework deploy orion documentation

* docs: :memo: finalize deployment docs

* docs: :memo: minor improvements in the documentations

* Update README.md

* Extend session based on activity after initial expiry is over (#287)

* Index most used field for ordering (#246)

* Add required indexes to nft and video entity

* Regen migrations

* Add index at event timestamp field

* Regen migrations

* Regen migrations v2

* Regen migrations v3

* Fix/notification email title (#289)

* Add new property to each notification type

* Use new subject property in email

* Remove app name from subject

* Orion setup improvements (#288)

* fix: deadlock issue caused by migration scripts

* gitignore src/types/

* update nodejs version to node:18

* added 'generate-migrations' makefile  command to generate migrations

* add npm command to get graphql chema

* add opentelemetry tracing integration with graphql-server and auth-server

* update docker.yml github workflow

* fix: DistributionBucketsCache init bug

* Improved offchain import/export script

* fix: dockerfile

* fix: dockerfile

* fix eslint issues

* fix checks.yml github workflow

* regenerate db migration files

* fix: Don't expose db container ports

* fix notification errors

* merge upstream/master

* Version 3.2.1 (#290)

* fix: deadlock issue caused by migration scripts

* gitignore src/types/

* update nodejs version to node:18

* added 'generate-migrations' makefile  command to generate migrations

* add npm command to get graphql chema

* add opentelemetry tracing integration with graphql-server and auth-server

* update docker.yml github workflow

* fix: DistributionBucketsCache init bug

* Improved offchain import/export script

* fix: dockerfile

* fix: dockerfile

* fix eslint issues

* fix checks.yml github workflow

* regenerate db migration files

* fix: Don't expose db container ports

* fix notification errors

* merge upstream/master

* remove unused property 'globalCountersMigration' from OffchainState

* refactor notifications scripts

* bump package version and update changelog

* 🐉 Homepage language improvements (#295)

* Add language utils

* Add new property to schema

* Try to predict language for each video

* Generate new mappings

* 🦢 Switch language package (#296)

* Replace ngram package

* Remove fallback to metadata language

* Add language predition to the update mapping

* Changelog and version bump

* Orion db migrations and state export fixes (#298)

* read/write export.json file using big-json package

* patch @subsquid/typeorm-config & @subsquid/typeorm-migration packages to change 'squid-typeorm-migration apply' commad to apply a single migrations file too

* regenerate the postgres db migrations

* update package version and add changelog

* added custom migration to set orionLanguage to all of the processed videos

* update *-Data.js migration file

* rename *-Operator.js migrations file

* rename *-Indexes.js migrations file

* patch @subsquid/openreader and @subsquid/typeorm-codegen dependencies  include the db schema too in the generated postgres migrations, and a 'schema' directive to specify the schema of any entity

* create *-Admin.js migration to create an admin schema & user

* separate the view definitions from views migration file

* create JS script to create new views migrations file.

* add @schema direcitve to hidden entities in graphql schema definitions

* regenerate db/migrations

* update 'generate-migrations' makefile command

* updated documentation for upgrading orion and entity visibility

* update CHANGELOG

* create VIEWs for hidden entities too

* fix: use snake case property names in createQueryBuilder instance methods

* fix: .gitignore not working

* fix lint issues

* re-generate db migrations

* Add is short field to video entity (#301)

* add isShort field to video entity

* regenerate db migrations

* remove @joystream/metadata-protobuf patch from assets/patches

* fix lint issue

* Disable both in Appp and eail notifications for video posted events (#299)

* bump package version and update CHANGELOG (#302)

* bump package version and update CHANGELOG

* change release version

* Simple public homefeed query and mutation (#304)

* update graphql schema

* add partial index on 'video.include_in_home_feed' field

* update video view definition to only include public videos

* regenerate migrations

* add dumbPublicFeedVideos custom query

* add setPublicFeedVideos mutation

* fix lint issue

* add arg to skip video IDs

* revert: update video view definition to only include public videos

* add feat. to unset public feed videos

* address requested change

* bump package version and update CHANGELOG

* commit register.html.mst file

* fix: notifications integration test

---------

Co-authored-by: Ignazio Bovo <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: omahs <[email protected]>
Co-authored-by: Theophile Sandoz <[email protected]>
Co-authored-by: attemka <[email protected]>

* 🦿 CRT marketplace changes (#285)

* Add new field and index to creator token

* Add mutation to feature crts

* Schema typo fix

* Add is short field to video entity (#301)

* add isShort field to video entity

* regenerate db migrations

* remove @joystream/metadata-protobuf patch from assets/patches

* fix lint issue

* Disable both in Appp and eail notifications for video posted events (#299)

* bump package version and update CHANGELOG (#302)

* bump package version and update CHANGELOG

* change release version

* Simple public homefeed query and mutation (#304)

* update graphql schema

* add partial index on 'video.include_in_home_feed' field

* update video view definition to only include public videos

* regenerate migrations

* add dumbPublicFeedVideos custom query

* add setPublicFeedVideos mutation

* fix lint issue

* add arg to skip video IDs

* revert: update video view definition to only include public videos

* add feat. to unset public feed videos

* address requested change

* bump package version and update CHANGELOG

* Update `nara` from `master` (#300)

* Adds mappings for `ChannelAssetsDeletedByModerator` & `VideoAssetsDeletedByModerator` events (#199)

* mark 'VideoDeletedByModerator' & 'ChannelDeletedByModerator' events deprecated

* Implements mappings for 'Content.VideoAssetsDeletedByModerator and 'Content.ChannelAssetsDeletedByModerator' runtime events

* remove unused import

* Nara/crt update (#244)

* feat: build orion

* feat: start generating schema

* fix: extra entities

* fixup!

* fix: continue implementing design specs

* fix: review and fix foreign key relationships

* fix: formatting

* fix: generation errors

* fix: add comment

* fix: relations

* fix: final review

* fixup!

* fix: add ending blocks

* fix: generate type & set typegen to ipv4

* fix: add support for event backward compatibility

* feat: start adding mappings

* fix: continue with mappnigs

* feat: init sale

* feat: patronage decreased to & fixed build

* feat: claim patronage event

* feat: tokens bought on amm

* feat: tokens sold on amm

* fix: add relation between sales and vesting schedules

* feat: add Tokens sold on sale vente

* feat: update upcoming sale

* feat: revenue share issued

* feat: member joined whitelist

* feat: amm deactivated

* feat: burned token

* feat: transfer policy changed to permissionless

* feat: sale finalized

* feat: finish mappings

* fix: review

* fix: remove cascade deletions

* fix: renaming & formatting

* fixup!

* fixup!

* fix: patched protobuf packages with token proto

* feat: update metadata and add event handler scheleton

* feat: token metadata

* feat: sale metadata

* fix: review comments

* fix: formatting

* fix: revenue

* Revert "fix: revenue"

This reverts commit 0821abe1e5e19be37a8d9a25d621dd148f03be9c.

* fix: token status after sale

* fix: fixmes

* fix: formatting

* fix: funds accounting during sale

* fix: amount accounting

* fix: linter

* fix: review

* fix: review 2

* fix: review

* fix: linter

* feat: migration for new db scheam

* fix: update event versions

* fix: patch types with crt_release types

* fix: patch types

* fix: generate all events versions since mainnet

* fix: temp fix after event version generation

* fix: event versioning

* fix: add migration

* fix: mignations

* fix: solve channel not being added

* fix: add id to TokenChannel

* fix: non-nullable deleted field set

* fix: format

* feat: creator token init sale re enabling

* feat: re enable sale init code

* fix: update types

* fix: amm id

* fix: id computation for revenue share

* fix: amm id computation for token

* fix: issuer transfer accounting

* fix: amm tx id

* fix: destination accounting

* feat: minor fix on holder transfer processing

* fix: re-enable metadata

* fix: metadata parsing

* fix: post reword cleanup

* fix: format

* fix: silence ci checks

* fix: event version

* fix: address PR changes

I edited all the entity that have a composite index like TokenAccount so that they have
a synthetic ID and an optionally unique @index

* fix: add hidden entities conditions

* fix: add extra fields to token in order to keep track of ongoing status

* fix: build errors

* fix: adapt mapping to new token fields

* fix: format

* feat: add trailer video entity

this is required so we can simply make trailer video hidden if video is hidden

* fix: linter

* chore: prettier

* fix: from PR review

* fix: vesting schedule schema & mappings

I have replaced the vesting schedule back to the original schema with:
- VestingSchedule: holding vesting schedule information such being amount agnostic
- VestedAccount: contains information regarded to a vested account, the goal is to mimic the
runtime logic

* fix: burning from vesting

* patch: metadata-protobuf package

* patch: metadata-protobuf package

* fix: generate migrations

* fix: purchase token on sale

* Update schema/token.graphql

Co-authored-by: Leszek Wiesner <[email protected]>

* Update schema/token.graphql

Co-authored-by: Leszek Wiesner <[email protected]>

* fix: address PR

* fix: hidden entities

* fix: migration ok

* feat: add extra check for migrations

* fix: docker network

* fix: format

* fix: remove unrequired constraint

* fix: :bug: post rebase fixes

* feat: :art: add metadata processing for issue token

* feat(crt-v1): :sparkles: chain metadata for v 2003

* fix(crt-v1): :ambulance: comment out view element for orion playgroud

* fix(crt-v1): :art: add playground config variable to .env

* feat: :white_check_mark: add tests

* fix(crt-v1): :package: packages and patches

* fix(crt-v1): :white_check_mark: update entity id used and other minor fixes

* fix(crt-v1): :white_check_mark: update entity id used and other minor fixes

* test(crt-v1): :bug: misc fixes to have tests working

* test(crt-v1): :bug: misc fixes to have tests working

* fix(crt-v1): :bug: metadata and trailer video

* feat(crt-v1): :art: update types

* fix(crt-v1): :sparkles: Add correct Ratio denomination (Permill)

* update with master

* fix: :bug: metadata not being set

* fix: :bug: parameters order

* test: :test_tube: fixing integration tests

* test(crt-v1): :test_tube: fix integration tests

* feat(crt-v1): :sparkles: last price for token and recovered field for rev share part

* feat: :sparkles: add resolver for dividend amount

* feat(crt-v1): :sparkles: start adding channel fields for trackingtotal revenue

* feat(crt-v1): :sparkles: add utils for royalty computation

* feat(crt-v1): :sparkles: cumulative revenue on channel

* feat(crt-v1): :sparkles: add resolver for transferrable amount

* fix(crt-v1): :sparkles: add `acquiredAt` to pinpoint latest vesting schedule for account

* Token metadata processing update

* Prettier

* chore(crt-v1): :zap: dbgen

* fix(crt-v1): :test_tube: fix integration tests

* fix(crt-v1): :bug: missing fields in token sale vesting source

* test(crt-v1): :test_tube: test for transferrable balance amount

* fix(crt-v1): :bug: transferrable amount

* test: :test_tube: update tests after resolver fix

* fix: :bug: error on vesting schedules array

* fix: :art: CI fixes

* docs: update gitignore

* fix: :rotating_light: prettier

* build: :pushpin: chai depnedencies

---------

Co-authored-by: Leszek Wiesner <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* Clear benefits even if not passed (#282)

* 🤑 Fix revenue share dividend estimation (#297)

* Fix on revenue share dividend estimation

* Fix type on result

* 🛕 Historical revenue share participants (#286)

* New field for revenue share

* Set potential revenue share particitants at the time of start

* fix: .gitignore not working

* fix lint issues

* re-generate db migrations

* commit register.html.mst file

* fix: notifications integration test

---------

Co-authored-by: Ignazio Bovo <[email protected]>
Co-authored-by: Leszek Wiesner <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>
Co-authored-by: WRadoslaw <[email protected]>

* Revert "Update `nara` from `master` (#300)" (#306)

This reverts commit 887427c75548417dedc741f9b258f7d49e1a0b4e.

* generate auth api docs and types

---------

Co-authored-by: Zeeshan Akram <[email protected]>
Co-authored-by: Ignazio Bovo <[email protected]>
Co-authored-by: Leszek Wiesner <[email protected]>
Co-authored-by: Zeeshan Akram <[email protected]>

* fix :re-generate migrations & set CreatorToken.isFeatured default value (#308)

* Feat/crt notifications (#267)

* User accounts notifications (#164)

* feat: squash all commits for notification demo

fix: add notification and template choice

feat: sketch mutation for setting the prefeences

fix: arguments for preference selection function

feat: add runtime notification data and notification preferences

fix: notification for runtime events

fix: add notification preference mutation

feat: add email strategy

fix: split Notification into onchain and offchain

fix: add channel created event notifiation

feat: distinguisher between member and channel notifiation

feat: enable offchain notification entities export

fix: notification preferences resolver

fix: migration

feat: default notification preferences

feat: start adding tests

fix: tests

fix: tests

fix: notificatino preference mutation and complete test

fix: add support for offchain dat

fix: missc

fix: format & fix build errors

fix: build and migrations

fix: bugs in setting notifications

fix: add case for notification mutation status

fix: build errors

fix: format

fix: data

* fix: remove non needed entity for migration

export / import scripts allows to specify fields of entities which will be migrated
In this case runtime notification will be migrated partially by offchain and partiall
by handlers

* feat: mark notifications as read

* fix: runtime notification migration generation

* feat: add event notification for video posted

* feat: add video comment

* feat: add chanel verification mutation

* feat: video excluded from app notifications

* feat: channel exclusion

* fix: Channel exclusion

* feat: notification deposit for video reaction

* feat: reaction for comment notifi…
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants