forked from openwallet-foundation/didcomm-mediator-credo
-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #28 from credebl/refactor/mediator
feat: push notifications
- Loading branch information
Showing
39 changed files
with
2,304 additions
and
501 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
diff --git a/node_modules/@credo-ts/core/build/agent/MessageSender.js b/node_modules/@credo-ts/core/build/agent/MessageSender.js | ||
index 689b024..656a3b5 100644 | ||
--- a/node_modules/@credo-ts/core/build/agent/MessageSender.js | ||
+++ b/node_modules/@credo-ts/core/build/agent/MessageSender.js | ||
@@ -75,7 +75,7 @@ let MessageSender = class MessageSender { | ||
this.logger.debug('Sending message'); | ||
await session.send(agentContext, encryptedMessage); | ||
} | ||
- async sendPackage(agentContext, { connection, encryptedMessage, recipientKey, options, }) { | ||
+ async sendPackage(agentContext, { connection, encryptedMessage, recipientKey, options, messageType, }) { | ||
var _a, e_1, _b, _c; | ||
var _d; | ||
const errors = []; | ||
@@ -145,6 +145,7 @@ let MessageSender = class MessageSender { | ||
connectionId: connection.id, | ||
recipientDids: [(0, helpers_1.verkeyToDidKey)(recipientKey)], | ||
payload: encryptedMessage, | ||
+ messageType, | ||
}); | ||
return; | ||
} | ||
diff --git a/node_modules/@credo-ts/core/build/modules/message-pickup/storage/MessagePickupRepositoryOptions.d.ts b/node_modules/@credo-ts/core/build/modules/message-pickup/storage/MessagePickupRepositoryOptions.d.ts | ||
index decb61a..b0c4342 100644 | ||
--- a/node_modules/@credo-ts/core/build/modules/message-pickup/storage/MessagePickupRepositoryOptions.d.ts | ||
+++ b/node_modules/@credo-ts/core/build/modules/message-pickup/storage/MessagePickupRepositoryOptions.d.ts | ||
@@ -13,6 +13,7 @@ export interface AddMessageOptions { | ||
connectionId: string; | ||
recipientDids: string[]; | ||
payload: EncryptedMessage; | ||
+ messageType?: string; | ||
} | ||
export interface RemoveMessagesOptions { | ||
connectionId: string; | ||
diff --git a/node_modules/@credo-ts/core/build/modules/routing/services/MediatorService.js b/node_modules/@credo-ts/core/build/modules/routing/services/MediatorService.js | ||
index 6818a3b..6474136 100644 | ||
--- a/node_modules/@credo-ts/core/build/modules/routing/services/MediatorService.js | ||
+++ b/node_modules/@credo-ts/core/build/modules/routing/services/MediatorService.js | ||
@@ -99,6 +99,7 @@ let MediatorService = class MediatorService { | ||
connection, | ||
recipientKey: (0, helpers_1.verkeyToDidKey)(message.to), | ||
encryptedMessage: message.message, | ||
+ messageType: message.messageType, | ||
}); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
import type { FcmDeviceInfo } from './models' | ||
|
||
import { OutboundMessageContext, AgentContext, ConnectionService, injectable, MessageSender } from '@credo-ts/core' | ||
|
||
import { PushNotificationsFcmService } from './services/PushNotificationsFcmService' | ||
import { | ||
PushNotificationsFcmDeviceInfoHandler, | ||
PushNotificationsFcmProblemReportHandler, | ||
PushNotificationsFcmSetDeviceInfoHandler, | ||
} from './handlers' | ||
|
||
@injectable() | ||
export class PushNotificationsFcmApi { | ||
private messageSender: MessageSender | ||
private pushNotificationsService: PushNotificationsFcmService | ||
private connectionService: ConnectionService | ||
private agentContext: AgentContext | ||
|
||
public constructor( | ||
messageSender: MessageSender, | ||
pushNotificationsService: PushNotificationsFcmService, | ||
connectionService: ConnectionService, | ||
agentContext: AgentContext | ||
) { | ||
this.messageSender = messageSender | ||
this.pushNotificationsService = pushNotificationsService | ||
this.connectionService = connectionService | ||
this.agentContext = agentContext | ||
|
||
this.agentContext.dependencyManager.registerMessageHandlers([ | ||
new PushNotificationsFcmSetDeviceInfoHandler(this.pushNotificationsService), | ||
new PushNotificationsFcmDeviceInfoHandler(), | ||
new PushNotificationsFcmProblemReportHandler(this.pushNotificationsService), | ||
]) | ||
} | ||
|
||
/** | ||
* Sends the requested fcm device info (token) to another agent via a `connectionId` | ||
* Response for `push-notifications-fcm/get-device-info` | ||
* | ||
* @param connectionId The connection ID string | ||
* @param threadId get-device-info message ID | ||
* @param deviceInfo The FCM device info | ||
* @returns Promise<void> | ||
*/ | ||
public async deviceInfo(options: { connectionId: string; threadId: string; deviceInfo: FcmDeviceInfo }) { | ||
const { connectionId, threadId, deviceInfo } = options | ||
const connection = await this.connectionService.getById(this.agentContext, connectionId) | ||
connection.assertReady() | ||
|
||
const message = this.pushNotificationsService.createDeviceInfo({ threadId, deviceInfo }) | ||
|
||
const outbound = new OutboundMessageContext(message, { | ||
agentContext: this.agentContext, | ||
connection: connection, | ||
}) | ||
await this.messageSender.sendMessage(outbound) | ||
} | ||
} |
Oops, something went wrong.