digiteinfotech / kairon

Conversational AI Platform to build effective Proactive Digital Assistants using Visual LLM Chaining
https://kairon.nimblework.com/bots
Apache License 2.0
248 stars 78 forks source link

1. removed kscheduler from action server and use mongo jobstore and e… #1466

Closed sfahad1414 closed 2 months ago

sfahad1414 commented 2 months ago

…vent server api to notify

  1. library updated and test cases fixed

Summary by CodeRabbit

coderabbitai[bot] commented 2 months ago

Walkthrough

The updates encompass modifications across various files, enhancing functionalities related to bot management, scheduling actions, email notifications, and payment processing. Key changes include the introduction of new methods, adjustments to existing method signatures, and the addition of new email templates and constants. The testing framework has also been improved with new test cases and updated assertions to reflect changes in the application logic and data structures.

Changes

Files Change Summary
augmentation/utils.py Updated get_qna function to improve text gathering from sibling HTML elements using a for loop instead of a while loop.
email.yaml Added new email templates for notifications when a user leaves a bot.
kairon/actions/definitions/schedule.py Replaced schedule method with add_schedule_job, introducing asynchronous job scheduling and MongoDB integration.
kairon/api/app/routers/user.py Introduced leave_bot endpoint for users to exit a bot, notifying owners via email.
kairon/chat/handlers/channels/whatsapp.py Enhanced message handling to include payment messages and updated logging for recipient information.
kairon/shared/account/data_objects.py Added leave_bot_owner_notification field to MailTemplates class.
kairon/shared/account/processor.py Introduced process_leave_bot method for handling user departure from a bot and updated email template loading.
kairon/shared/actions/utils.py Reformatted execute_request_async method signature for better readability.
kairon/shared/chat/processor.py Updated save_whatsapp_audit_log method to include recipient parameter and refined data handling for payment statuses.
kairon/shared/constants.py Added payment enumeration value to KaironSystemSlots class.
kairon/shared/data/processor.py Updated add_system_required_slots method to include payment slot in non-conversational slots.
kairon/shared/sso/clients/linkedin.py Modified process_login method to include new parameters for enhanced authentication flows.
kairon/shared/utils.py Added __handle_member_left_bot method for constructing email notifications for bot owners.
requirements/dev.txt Updated versions of several Python packages for development dependencies.
requirements/prod.txt Upgraded various dependencies in production requirements for improved functionality and security.
template/emails/leaveBotOwnerNotification.html Created new HTML template for notifying bot owners when a member leaves.
tests/integration_test/action_service_test.py Restructured tests for scheduling actions, adding new test cases and removing outdated ones.
tests/integration_test/chat_service_test.py Added tests for processing WhatsApp payment messages and updated assertions for recipient validation.
tests/integration_test/services_test.py Updated assertions for bot membership and integration tokens, adding new tests for leaving a bot.
tests/unit_test/callback_test.py Updated access token in Telegram tests to a specific value.
tests/unit_test/data_processor/data_processor_test.py Adjusted expected counts of slots and entities in various tests to reflect changes in the data model.
tests/unit_test/events/definitions_test.py Updated URLs in tests and modified matcher syntax for website data generation tests.

Sequence Diagram(s)

sequenceDiagram
    participant User
    participant Bot
    participant MailUtility
    participant AccountProcessor

    User->>Bot: Request to leave bot
    Bot->>AccountProcessor: Process leave request
    AccountProcessor->>MailUtility: Send notification to bot owner
    MailUtility->>User: Confirmation of leave

🐰 In the meadow where I hop and play,
Changes bloom like flowers in May.
New paths for bots, and emails to send,
With joyful leaps, our code will mend!
Hooray for updates, let’s dance and cheer,
For every change brings us more near! 🌼


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

Share - [X](https://twitter.com/intent/tweet?text=I%20just%20used%20%40coderabbitai%20for%20my%20code%20review%2C%20and%20it%27s%20fantastic%21%20It%27s%20free%20for%20OSS%20and%20offers%20a%20free%20trial%20for%20the%20proprietary%20code.%20Check%20it%20out%3A&url=https%3A//coderabbit.ai) - [Mastodon](https://mastodon.social/share?text=I%20just%20used%20%40coderabbitai%20for%20my%20code%20review%2C%20and%20it%27s%20fantastic%21%20It%27s%20free%20for%20OSS%20and%20offers%20a%20free%20trial%20for%20the%20proprietary%20code.%20Check%20it%20out%3A%20https%3A%2F%2Fcoderabbit.ai) - [Reddit](https://www.reddit.com/submit?title=Great%20tool%20for%20code%20review%20-%20CodeRabbit&text=I%20just%20used%20CodeRabbit%20for%20my%20code%20review%2C%20and%20it%27s%20fantastic%21%20It%27s%20free%20for%20OSS%20and%20offers%20a%20free%20trial%20for%20proprietary%20code.%20Check%20it%20out%3A%20https%3A//coderabbit.ai) - [LinkedIn](https://www.linkedin.com/sharing/share-offsite/?url=https%3A%2F%2Fcoderabbit.ai&mini=true&title=Great%20tool%20for%20code%20review%20-%20CodeRabbit&summary=I%20just%20used%20CodeRabbit%20for%20my%20code%20review%2C%20and%20it%27s%20fantastic%21%20It%27s%20free%20for%20OSS%20and%20offers%20a%20free%20trial%20for%20proprietary%20code)
Tips ### Chat There are 3 ways to chat with [CodeRabbit](https://coderabbit.ai): - Review comments: Directly reply to a review comment made by CodeRabbit. Example: - `I pushed a fix in commit .` - `Generate unit testing code for this file.` - `Open a follow-up GitHub issue for this discussion.` - Files and specific lines of code (under the "Files changed" tab): Tag `@coderabbitai` in a new review comment at the desired location with your query. Examples: - `@coderabbitai generate unit testing code for this file.` - `@coderabbitai modularize this function.` - PR comments: Tag `@coderabbitai` in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples: - `@coderabbitai generate interesting stats about this repository and render them as a table.` - `@coderabbitai show all the console.log statements in this repository.` - `@coderabbitai read src/utils.ts and generate unit testing code.` - `@coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.` - `@coderabbitai help me debug CodeRabbit configuration file.` Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. ### CodeRabbit Commands (Invoked using PR comments) - `@coderabbitai pause` to pause the reviews on a PR. - `@coderabbitai resume` to resume the paused reviews. - `@coderabbitai review` to trigger an incremental review. This is useful when automatic reviews are disabled for the repository. - `@coderabbitai full review` to do a full review from scratch and review all the files again. - `@coderabbitai summary` to regenerate the summary of the PR. - `@coderabbitai resolve` resolve all the CodeRabbit review comments. - `@coderabbitai configuration` to show the current CodeRabbit configuration for the repository. - `@coderabbitai help` to get help. ### Other keywords and placeholders - Add `@coderabbitai ignore` anywhere in the PR description to prevent this PR from being reviewed. - Add `@coderabbitai summary` to generate the high-level summary at a specific location in the PR description. - Add `@coderabbitai` anywhere in the PR title to generate the title automatically. ### CodeRabbit Configuration File (`.coderabbit.yaml`) - You can programmatically configure CodeRabbit by adding a `.coderabbit.yaml` file to the root of your repository. - Please see the [configuration documentation](https://docs.coderabbit.ai/guides/configure-coderabbit) for more information. - If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: `# yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json` ### Documentation and Community - Visit our [Documentation](https://coderabbit.ai/docs) for detailed information on how to use CodeRabbit. - Join our [Discord Community](https://discord.com/invite/GsXnASn26c) to get help, request features, and share feedback. - Follow us on [X/Twitter](https://twitter.com/coderabbitai) for updates and announcements.