|
DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MI DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MILVAll 4DMsloastApp[no preview availablel11 | 10:00 AMIMonday. May 4th-7 Jira Cloud@ 15 Monday@Nikolay Ivanov transitioned aBug you are watching from Code...Wednesday, April 29thAneliva AngelovaWednesdayStoyan Tanev6 DMWednesdavнаша стоананTuesday. April 28th?1 Stefka StoyanovaApr 28thтия тикети е добре да влезнат вдругия спринт ли? сложете някакви...Ves@ Thread in DM: исках да те...смени го в Circle Cl env на новиятокон който си наппарилApr 28thStefka Stoyano… Replied Apr 28thAOMIприятна отпуска ®Stetka Stovanova and …... Aor 28thlWindow* → CN& Adelina Petrova "Pull requests • screenpipe/screenpipe - GitHubMessagesLo Add canvasUr Files# Hostinger login | Sign in to Hostinger accountне, само стр се тракватLogin - Nginx Proxy ManagerLukas Kovalik IN 1:15 PM* Screenpipe - ArchiveAdelina Petrova "T 1:42 PMpagesLukas Kovalik "T 1:43 PMЯСНО@ SQLite Web: archive.db©SQLite Web: db.sqliteAdelina Petrova 5:06 PMда не ои проолема да е заради това кю: QUEUE,DELAYA- New TabLukas Kovalik * 5:06 PMscreenpipe/,claude/skills at main • screenpipe/screenpза това искам да дооавя логовеAdelina Petrova 5:07 PMUAVDA MO CTAUG SUA rA MaVUOLI?има ли риск за нещоLukas Kovalik " 5:08 PMвсишност нама опашка тукаAdelina Petrova " 5:12 PM• сега, няма ли ла сложи евента в това кю и ла чака изпьлLukas Kovalik *T 5:21 PMла, ше оставя detault изпь лнениеLukas Kovalik 1K 5-26 PMпо поинцип го направих като nudge-created че те не са оl•и глелам че и този event няма никойAdelina Petrova 5:33PMспорел мен пробвай без това кюLukas Kovalik * 5:33 PMhttps://run.userpilot.io/events/tracked_event/10run.userpilot.ioUserpilotUserpilot helos product teams deliver personalized in-appgrowth metrics at every stage of the user lournev.не е това обаче, гледам че всички си минават през сьщиAdelina Petrova * 5:40 PMами эко можеш сложи тогава лог да го видимAdelina Petrova has paused their notificationsMessage Adelina Petrova " VacationingAaO Not Secure http:/[IP_ADDRESS]:8768/audio_transcriptions_fts_idx/auaio taasaudio_transcriptionsaudio_transcriptions_fts (v)audio_transcriptions_.102008 2-= ArchiveCREATE TABLE 'audio_transcriptions_fts_idx' (segid,cerm,PRIMARY KEV(segid, term)ColumnsColumnsegidtermpgnoIndexesNameData typeColumnsSQLite database browser vO.7.2, powered by Flask and Peewee. © 2026 Charles LeiferAllow nullframesframes_fts (v)frames_fts_configframes_fts_dataframes_fts_idxmeetingsmemoriesmemories_fts (v)memories_fts_configmemories_fts_datamemories_fts_idxocr_textpipe_executionspipe_scheduler_statesecretsspeaker_embeddingsspeakerssalite_sequencesqlite_stat1sqlite_stat4tagsui_eventsui_events_fts (v)ui_events_fts_configui_events_fts_dataui_events_fts_idxvideo_chunksvision_tagsToggle helper tablesUniqueQOOA 048 Wed6May 20:52:03Primary keySQLActionsread-onlvread-onlyread-onlyDrop?...
|
iTerm2
|
NULL
|
NULL
|
|
DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MI DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MILVAll 4DMsloastApp[no preview availablel11 | 10:00 AMIMonday. May 4th-7 Jira Cloud@ 15 Monday@Nikolay Ivanov transitioned aBug you are watching from Code...Wednesday, April 29thAneliva AngelovaWednesdayStoyan Tanev6 DMWednesdavнаша стоананTuesday. April 28th?1 Stefka StoyanovaApr 28thтия тикети е добре да влезнат вдругия спринт ли? сложете някакви...Ves@ Thread in DM: исках да те...смени го в Circle Cl env на новиятокон който си наппарилApr 28thStefka Stoyano… Replied Apr 28thAOMIприятна отпуска ®Stetka Stovanova and …... Aor 28thlWindow* → CN& Adelina Petrova "Pull requests • screenpipe/screenpipe - GitHubMessagesLo Add canvasUr Files# Hostinger login | Sign in to Hostinger accountне, само стр се тракватLogin - Nginx Proxy ManagerLukas Kovalik IN 1:15 PM* Screenpipe - ArchiveAdelina Petrova "T 1:42 PMpagesLukas Kovalik "T 1:43 PMЯСНО@ SQLite Web: archive.db©SQLite Web: db.sqliteAdelina Petrova 5:06 PMда не ои проолема да е заради това кю: QUEUE,DELAYA- New TabLukas Kovalik * 5:06 PMscreenpipe/,claude/skills at main • screenpipe/screenpза това искам да дооавя логовеAdelina Petrova 5:07 PMUAVDA MO CTAUG SUA rA MaVUOLI?има ли риск за нещоLukas Kovalik " 5:08 PMвсишност нама опашка тукаAdelina Petrova " 5:12 PM• сега, няма ли ла сложи евента в това кю и ла чака изпьлLukas Kovalik *T 5:21 PMла, ше оставя detault изпь лнениеLukas Kovalik 1K 5-26 PMпо поинцип го направих като nudge-created че те не са оl•и глелам че и този event няма никойAdelina Petrova 5:33PMспорел мен пробвай без това кюLukas Kovalik * 5:33 PMhttps://run.userpilot.io/events/tracked_event/10run.userpilot.ioUserpilotUserpilot helos product teams deliver personalized in-appgrowth metrics at every stage of the user lournev.не е това обаче, гледам че всички си минават през сьщиAdelina Petrova * 5:40 PMами эко можеш сложи тогава лог да го видимAdelina Petrova has paused their notificationsMessage Adelina Petrova " VacationingAaO Not Secure http:/[IP_ADDRESS]:8768/audio_transcriptions_fts_idx/auaio taasaudio_transcriptionsaudio_transcriptions_fts (v)audio_transcriptions_.102008 2-= ArchiveCREATE TABLE 'audio_transcriptions_fts_idx' (segid,cerm,PRIMARY KEV(segid, term)ColumnsColumnsegidtermpgnoIndexesNameData typeColumnsSQLite database browser vO.7.2, powered by Flask and Peewee. © 2026 Charles LeiferAllow nullframesframes_fts (v)frames_fts_configframes_fts_dataframes_fts_idxmeetingsmemoriesmemories_fts (v)memories_fts_configmemories_fts_datamemories_fts_idxocr_textpipe_executionspipe_scheduler_statesecretsspeaker_embeddingsspeakerssalite_sequencesqlite_stat1sqlite_stat4tagsui_eventsui_events_fts (v)ui_events_fts_configui_events_fts_dataui_events_fts_idxvideo_chunksvision_tagsToggle helper tablesUniqueQOOA 048 Wed6May 20:52:35Primary keySQLActionsread-onlvread-onlyread-onlyDrop?...
|
iTerm2
|
NULL
|
NULL
|
|
DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MI DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MILVAll 4DMsloastApp[no preview availablel11 | 10:00 AMIMonday. May 4th-7 Jira Cloud@ 15 Monday@Nikolay Ivanov transitioned aBug you are watching from Code...Wednesday, April 29thAneliva AngelovaWednesdayStoyan Tanev6 DMWednesdavнаша стоананTuesday. April 28th?1 Stefka StoyanovaApr 28thтия тикети е добре да влезнат вдругия спринт ли? сложете някакви...Ves@ Thread in DM: исках да те...смени го в Circle Cl env на новиятокон който си наппарилApr 28thStefka Stoyano… Replied Apr 28thAOMIприятна отпуска ®Stetka Stovanova and …... Aor 28thlWindow* → CN& Adelina Petrova "Pull requests • screenpipe/screenpipe - GitHubMessagesLo Add canvasUr Files# Hostinger login | Sign in to Hostinger accountне, само стр се тракватLogin - Nginx Proxy ManagerLukas Kovalik IN 1:15 PM* Screenpipe - ArchiveAdelina Petrova "T 1:42 PMpagesLukas Kovalik "T 1:43 PMЯСНО@ SQLite Web: archive.db©SQLite Web: db.sqliteAdelina Petrova 5:06 PMда не ои проолема да е заради това кю: QUEUE,DELAYA- New TabLukas Kovalik * 5:06 PMscreenpipe/,claude/skills at main • screenpipe/screenpза това искам да дооавя логовеAdelina Petrova 5:07 PMUAVDA MO CTAUG SUA rA MaVUOLI?има ли риск за нещоLukas Kovalik " 5:08 PMвсишност нама опашка тукаAdelina Petrova " 5:12 PM• сега, няма ли ла сложи евента в това кю и ла чака изпьлLukas Kovalik *T 5:21 PMла, ше оставя detault изпь лнениеLukas Kovalik 1K 5-26 PMпо поинцип го направих като nudge-created че те не са оl•и глелам че и този event няма никойAdelina Petrova 5:33PMспорел мен пробвай без това кюLukas Kovalik * 5:33 PMhttps://run.userpilot.io/events/tracked_event/10run.userpilot.ioUserpilotUserpilot helos product teams deliver personalized in-appgrowth metrics at every stage of the user lournev.не е това обаче, гледам че всички си минават през сьщиAdelina Petrova * 5:40 PMами эко можеш сложи тогава лог да го видимAdelina Petrova has paused their notificationsMessage Adelina Petrova " VacationingAaO Not Secure http:/[IP_ADDRESS]:8768/audio_transcriptions_fts_idx/auaio taasaudio_transcriptionsaudio_transcriptions_fts (v)audio_transcriptions_.102008 2-= ArchiveCREATE TABLE 'audio_transcriptions_fts_idx' (segid,cerm,PRIMARY KEV(segid, term)ColumnsColumnsegidtermpgnoIndexesNameData typeColumnsSQLite database browser vO.7.2, powered by Flask and Peewee. © 2026 Charles LeiferAllow nullframesframes_fts (v)frames_fts_configframes_fts_dataframes_fts_idxmeetingsmemoriesmemories_fts (v)memories_fts_configmemories_fts_datamemories_fts_idxocr_textpipe_executionspipe_scheduler_statesecretsspeaker_embeddingsspeakerssalite_sequencesqlite_stat1sqlite_stat4tagsui_eventsui_events_fts (v)ui_events_fts_configui_events_fts_dataui_events_fts_idxvideo_chunksvision_tagsToggle helper tablesUniqueQOOA 048 Wed6May 20:53:06Primary keySQLActionsread-onlvread-onlyread-onlyDrop?...
|
iTerm2
|
NULL
|
NULL
|
|
DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MI DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MILVAll 4DMsloastApp[no preview availablel11 | 10:00 AMIMonday. May 4th-7 Jira Cloud@ 15 Monday@Nikolay Ivanov transitioned aBug you are watching from Code...Wednesday, April 29thAneliva AngelovaWednesdayStoyan Tanev6 DMWednesdavнаша стоананTuesday. April 28th?1 Stefka StoyanovaApr 28thтия тикети е добре да влезнат вдругия спринт ли? сложете някакви...Ves@ Thread in DM: исках да те...смени го в Circle Cl env на новиятокон който си наппарилApr 28thStefka Stoyano… Replied Apr 28thAOMIприятна отпуска ®Stetka Stovanova and …... Aor 28thlWindow* → CN& Adelina Petrova "Pull requests • screenpipe/screenpipe - GitHubMessagesLo Add canvasUr Files# Hostinger login | Sign in to Hostinger accountне, само стр се тракватLogin - Nginx Proxy ManagerLukas Kovalik IN 1:15 PM* Screenpipe - ArchiveAdelina Petrova "T 1:42 PMpagesLukas Kovalik "T 1:43 PMЯСНО@ SQLite Web: archive.db©SQLite Web: db.sqliteAdelina Petrova 5:06 PMда не ои проолема да е заради това кю: QUEUE,DELAYA- New TabLukas Kovalik * 5:06 PMscreenpipe/,claude/skills at main • screenpipe/screenpза това искам да дооавя логовеAdelina Petrova 5:07 PMUAVDA MO CTAUG SUA rA MaVUOLI?има ли риск за нещоLukas Kovalik " 5:08 PMвсишност нама опашка тукаAdelina Petrova " 5:12 PM• сега, няма ли ла сложи евента в това кю и ла чака изпьлLukas Kovalik *T 5:21 PMла, ше оставя detault изпь лнениеLukas Kovalik 1K 5-26 PMпо поинцип го направих като nudge-created че те не са оl•и глелам че и този event няма никойAdelina Petrova 5:33PMспорел мен пробвай без това кюLukas Kovalik * 5:33 PMhttps://run.userpilot.io/events/tracked_event/10run.userpilot.ioUserpilotUserpilot helos product teams deliver personalized in-appgrowth metrics at every stage of the user lournev.не е това обаче, гледам че всички си минават през сьщиAdelina Petrova * 5:40 PMами эко можеш сложи тогава лог да го видимAdelina Petrova has paused their notificationsMessage Adelina Petrova " VacationingAaO Not Secure http:/[IP_ADDRESS]:8768/audio_transcriptions_fts_idx/auaio taasaudio_transcriptionsaudio_transcriptions_fts (v)audio_transcriptions_.102008 2-= ArchiveCREATE TABLE 'audio_transcriptions_fts_idx' (segid,cerm,PRIMARY KEV(segid, term)ColumnsColumnsegidtermpgnoIndexesNameData typeColumnsSQLite database browser vO.7.2, powered by Flask and Peewee. © 2026 Charles LeiferAllow nullframesframes_fts (v)frames_fts_configframes_fts_dataframes_fts_idxmeetingsmemoriesmemories_fts (v)memories_fts_configmemories_fts_datamemories_fts_idxocr_textpipe_executionspipe_scheduler_statesecretsspeaker_embeddingsspeakerssalite_sequencesqlite_stat1sqlite_stat4tagsui_eventsui_events_fts (v)ui_events_fts_configui_events_fts_dataui_events_fts_idxvideo_chunksvision_tagsToggle helper tablesUniqueQOOA 048 Wed6May 20:53:38Primary keySQLActionsread-onlvread-onlyread-onlyDrop?...
|
iTerm2
|
NULL
|
NULL
|
|
DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MI DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MILVAll 4DMsloastApp[no preview availablel11 | 10:00 AMIMonday. May 4th-7 Jira Cloud@ 15 Monday@Nikolay Ivanov transitioned aBug you are watching from Code...Wednesday, April 29thAneliva AngelovaWednesdayStoyan Tanev6 DMWednesdavнаша стоананTuesday. April 28th?1 Stefka StoyanovaApr 28thтия тикети е добре да влезнат вдругия спринт ли? сложете някакви...Ves@ Thread in DM: исках да те...смени го в Circle Cl env на новиятокон който си наппарилApr 28thStefka Stoyano… Replied Apr 28thAOMIприятна отпуска ®Stetka Stovanova and …... Aor 28thlWindow* → CN& Adelina Petrova "Pull requests • screenpipe/screenpipe - GitHubMessagesLo Add canvasUr Files# Hostinger login | Sign in to Hostinger accountне, само стр се тракватLogin - Nginx Proxy ManagerLukas Kovalik IN 1:15 PM* Screenpipe - ArchiveAdelina Petrova "T 1:42 PMpagesLukas Kovalik "T 1:43 PMЯСНО@ SQLite Web: archive.db©SQLite Web: db.sqliteAdelina Petrova 5:06 PMда не ои проолема да е заради това кю: QUEUE,DELAYA- New TabLukas Kovalik * 5:06 PMscreenpipe/,claude/skills at main • screenpipe/screenpза това искам да дооавя логовеAdelina Petrova 5:07 PMUAVDA MO CTAUG SUA rA MaVUOLI?има ли риск за нещоLukas Kovalik " 5:08 PMвсишност нама опашка тукаAdelina Petrova " 5:12 PM• сега, няма ли ла сложи евента в това кю и ла чака изпьлLukas Kovalik *T 5:21 PMла, ше оставя detault изпь лнениеLukas Kovalik 1K 5-26 PMпо поинцип го направих като nudge-created че те не са оl•и глелам че и този event няма никойAdelina Petrova 5:33PMспорел мен пробвай без това кюLukas Kovalik * 5:33 PMhttps://run.userpilot.io/events/tracked_event/10run.userpilot.ioUserpilotUserpilot helos product teams deliver personalized in-appgrowth metrics at every stage of the user lournev.не е това обаче, гледам че всички си минават през сьщиAdelina Petrova * 5:40 PMами эко можеш сложи тогава лог да го видимAdelina Petrova has paused their notificationsMessage Adelina Petrova " VacationingAaO Not Secure http:/[IP_ADDRESS]:8768/audio_transcriptions_fts_idx/auaio taasaudio_transcriptionsaudio_transcriptions_fts (v)audio_transcriptions_.102008 2-= ArchiveCREATE TABLE 'audio_transcriptions_fts_idx' (segid,cerm,PRIMARY KEV(segid, term)ColumnsColumnsegidtermpgnoIndexesNameData typeColumnsSQLite database browser vO.7.2, powered by Flask and Peewee. © 2026 Charles LeiferAllow nullframesframes_fts (v)frames_fts_configframes_fts_dataframes_fts_idxmeetingsmemoriesmemories_fts (v)memories_fts_configmemories_fts_datamemories_fts_idxocr_textpipe_executionspipe_scheduler_statesecretsspeaker_embeddingsspeakerssalite_sequencesqlite_stat1sqlite_stat4tagsui_eventsui_events_fts (v)ui_events_fts_configui_events_fts_dataui_events_fts_idxvideo_chunksvision_tagsToggle helper tablesUniqueQOOA 048 Wed6May 20:54:10Primary keySQLActionsread-onlvread-onlyread-onlyDrop?...
|
iTerm2
|
NULL
|
NULL
|
|
DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MI DMSrireroxcalVIewhistorybookmarksProtllesHelpAC.MILVAll 4DMsloastApp[no preview availablel11 | 10:00 AMIMonday. May 4th-7 Jira Cloud@ 15 Monday@Nikolay Ivanov transitioned aBug you are watching from Code...Wednesday, April 29thAneliva AngelovaWednesdayStoyan Tanev6 DMWednesdavнаша стоананTuesday. April 28th?1 Stefka StoyanovaApr 28thтия тикети е добре да влезнат вдругия спринт ли? сложете някакви...Ves@ Thread in DM: исках да те...смени го в Circle Cl env на новиятокон който си наппарилApr 28thStefka Stoyano… Replied Apr 28thAOMIприятна отпуска ®Stetka Stovanova and …... Aor 28thlWindow* → CN& Adelina Petrova "Pull requests • screenpipe/screenpipe - GitHubMessagesLo Add canvasUr Files# Hostinger login | Sign in to Hostinger accountне, само стр се тракватLogin - Nginx Proxy ManagerLukas Kovalik IN 1:15 PM* Screenpipe - ArchiveAdelina Petrova "T 1:42 PMpagesLukas Kovalik "T 1:43 PMЯСНО@ SQLite Web: archive.db©SQLite Web: db.sqliteAdelina Petrova 5:06 PMда не ои проолема да е заради това кю: QUEUE,DELAYA- New TabLukas Kovalik * 5:06 PMscreenpipe/,claude/skills at main • screenpipe/screenpза това искам да дооавя логовеAdelina Petrova 5:07 PMUAVDA MO CTAUG SUA rA MaVUOLI?има ли риск за нещоLukas Kovalik " 5:08 PMвсишност нама опашка тукаAdelina Petrova " 5:12 PM• сега, няма ли ла сложи евента в това кю и ла чака изпьлLukas Kovalik *T 5:21 PMла, ше оставя detault изпь лнениеLukas Kovalik 1K 5-26 PMпо поинцип го направих като nudge-created че те не са оl•и глелам че и този event няма никойAdelina Petrova 5:33PMспорел мен пробвай без това кюLukas Kovalik * 5:33 PMhttps://run.userpilot.io/events/tracked_event/10run.userpilot.ioUserpilotUserpilot helos product teams deliver personalized in-appgrowth metrics at every stage of the user lournev.не е това обаче, гледам че всички си минават през сьщиAdelina Petrova * 5:40 PMами эко можеш сложи тогава лог да го видимAdelina Petrova has paused their notificationsMessage Adelina Petrova " VacationingAaO Not Secure http:/[IP_ADDRESS]:8768/audio_transcriptions_fts_idx/auaio taasaudio_transcriptionsaudio_transcriptions_fts (v)audio_transcriptions_.102008 2-= ArchiveCREATE TABLE 'audio_transcriptions_fts_idx' (segid,cerm,PRIMARY KEV(segid, term)ColumnsColumnsegidtermpgnoIndexesNameData typeColumnsSQLite database browser vO.7.2, powered by Flask and Peewee. © 2026 Charles LeiferAllow nullframesframes_fts (v)frames_fts_configframes_fts_dataframes_fts_idxmeetingsmemoriesmemories_fts (v)memories_fts_configmemories_fts_datamemories_fts_idxocr_textpipe_executionspipe_scheduler_statesecretsspeaker_embeddingsspeakerssalite_sequencesqlite_stat1sqlite_stat4tagsui_eventsui_events_fts (v)ui_events_fts_configui_events_fts_dataui_events_fts_idxvideo_chunksvision_tagsToggle helper tablesUniqueQOOAX 4 8 WedGMay 20:44:09Primary keySQLActionsread-onlvread-onlyread-onlyDrop?...
|
iTerm2
|
NULL
|
NULL
|
|
DNS / Nameservers | Hostinger
hpanel.hostinger.com DNS / Nameservers | Hostinger
hpanel.hostinger.com
Pull requests · screenpipe/screenpipe · GitHub
Close tab
DNS / Nameservers | Hostinger
Close tab
Nginx Proxy Manager
Close tab
Screenpipe — Archive
Close tab
SQLite Web: archive.db
Close tab
SQLite Web: db.sqlite
Close tab
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
Close tab
DXP4800PLUS-B5F8
Close tab
AFFiNE - All In One KnowledgeOS
Close tab
All docs · AFFiNE
Close tab
Payments Logger
Close tab
Your old PC can run Windows 11 in a VM, but not on bare metal - [EMAIL] - Gmail
Close tab
Location Logger
Close tab
Finance Hub
Close tab
Finance Hub
Close tab
Select: transactions - db - Adminer
Close tab
Claude Code | Claude Platform
Close tab
Claude
Close tab
lakylak/finance-hub - finance-hub - Gitea: Git with a cup of tea
Close tab
Applications - Admin - authentik
Close tab
New Tab
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
Customize sidebar
Skip to content
Home
Applications
External applications that use authentik as an identity provider via protocols like OAuth2 and SAML. All applications are shown here, even ones you cannot access.
External applications that use authentik as an identity provider via protocols like OAuth2 and SAML. All applications are shown here, even ones you cannot access.
Toggle API requests drawer
Toggle notifications drawer
0
unread
Settings
Sign out
User interface
User interface
Dashboards
Collapse Dashboards
Dashboards
Overview
Overview
User Statistics
User Statistics
System Tasks
System Tasks
Applications
Collapse Applications
Applications
Applications
Applications
Providers
Providers
Outposts
Outposts
Endpoint Devices
Expand Endpoint Devices
Endpoint Devices
Events
Expand Events
Events
Customization
Expand Customization
Customization
Flows and Stages
Expand Flows and Stages
Flows and Stages
Directory
Expand Directory
Directory
System
Expand System
System
Enterprise
Expand Enterprise
Enterprise
Product name
authentik
Product version
Version 2026.2.1
Select all rows on page (0 of 5 selected)
Application Icon
Name
Sort by "Name"
Name
Group
Sort by "Group"
Group
Provider
Provider
Provider Type
Provider Type
Row Actions
Actions
Select "Finance Hub" row
Finance Hub
Finance Hub
-
Finance Hub Proxy
Finance Hub Proxy
Proxy Provider
Edit "Finance Hub"
Open "Finance Hub"
Select "Finance Hub MCP" row
Finance Hub MCP
Finance Hub MCP
-
Finance Hub MCP
Finance Hub MCP
OAuth2/OpenID Provider
Edit "Finance Hub MCP"
Open "Finance Hub MCP"
Select "Open WebUI" row
Open WebUI
Open WebUI
-
open-webui
open-webui
OAuth2/OpenID Provider
Edit "Open WebUI"
Open "Open WebUI"
Select "Reminders" row
Reminders
Reminders
-
Reminders Proxy
Reminders Proxy
Proxy Provider
Edit "Reminders"
Open "Reminders"
Select "Reminders MCP" row
Reminders MCP
Reminders MCP
-
reminders-mcp
reminders-mcp
OAuth2/OpenID Provider
Edit "Reminders MCP"
Open "Reminders MCP"
Application Icon
Name
Sort by "Name"
Name
Finance Hub
Finance Hub
Finance Hub MCP
Finance Hub MCP
Open WebUI
Open WebUI
Reminders
Reminders
Reminders MCP
Reminders MCP
Group
Sort by "Group"
Group
-
-
-
-
-
Provider
Provider
Finance Hub Proxy
Finance Hub Proxy
Finance Hub MCP
Finance Hub MCP
open-webui
open-webui
Reminders Proxy
Reminders Proxy
reminders-mcp
reminders-mcp
Provider Type
Provider Type
Proxy Provider
OAuth2/OpenID Provider
OAuth2/OpenID Provider
Proxy Provider
OAuth2/OpenID Provider
Row Actions
Actions
Edit "Finance Hub"
Open "Finance Hub"
Edit "Finance Hub MCP"
Open "Finance Hub MCP"
Edit "Open WebUI"
Open "Open WebUI"
Edit "Reminders"
Open "Reminders"
Edit "Reminders MCP"
Open "Reminders MCP"
Last refreshed
1 minute ago
1 - 5 of 5
1 - 5 of 5
Go to previous page
Go to next page
Applications
Applications
Applications, as defined in authentik, are used to configure and separate the authorization/access control and the appearance of a specific software application in the
My applications
page.
When a user logs into authentik, they see a list of the applications for which authentik is configured to provide authentication and authorization (the applications that they are authorized to use).
Applications are the "other half" of providers. They typically exist in a 1-to-1 relationship; each application needs a provider and every provider can be used with one application. Applications can, however, use specific, additional providers to augment the functionality of the main provider. For more information, see
Backchannel providers
Backchannel providers
.
Furthermore, the
RAC (Remote Access Control)
RAC (Remote Access Control)
feature uses a single application and a single provider, but multiple "endpoints". An endpoint defines each remote machine.
For information about creating and managing applications, refer to
Manage applications
Manage applications
.
Appearance
Appearance
Applications are displayed to users when:
The user has access defined via policies (or the application has no policies bound)
A valid Launch URL is configured/could be guessed, this consists of URLs starting with http:// and https://
The following options can be configured:
Name
: This is the name shown for the application card
Launch URL
: The URL that is opened when a user clicks on the application. When left empty, authentik tries to guess it based on the provider
You can use placeholders in the launch url to build them dynamically based on the logged in user. For example, you can set the Launch URL to
https://goauthentik.io/%(username)s
, which will be replaced with the currently logged in user's username.
For a reference of all fields available, see
the API schema for the User object
the API schema for the User object
.
Only applications whose launch URL starts with
http://
or
https://
or are relative URLs are shown on the users'
My applications
page. This can also be used to hide applications that shouldn't be visible on the
My applications
page but are still accessible by users, by setting the
Launch URL
to
blank://blank
.
Icon (URL)
: Optionally configure an Icon for the application. You can select from files uploaded to the
Files
Files
library or enter an absolute URL.
Publisher
: Text shown in the application card's expandable kebab menu (⋮)
Description
: Text shown in the application card's expandable kebab menu (⋮)
Close sidebar...
|
Firefox
|
Applications - Admin - authentik — Personal
|
hpanel.hostinger.com/domain/lakylak.xyz/dns?tab=dn hpanel.hostinger.com/domain/lakylak.xyz/dns?tab=dns_records...
|
|
DOCKER2026-05-07110:12:16.55057022026-05-07T10:12: DOCKER2026-05-07110:12:16.55057022026-05-07T10:12:31.745217Z2026-05-07T10:12:34.790862Z2026-05-07110:12:37.78475222026-05-07T10:12:40.806177Z2026-05-07110:12:43.85488122026-05-07T10:12:59.015149Z2026-05-07T10:13:14.166750Z2026-05-07T10:13:17.184510Z2026-05-07T10:13:34.773468Z2026-05-07110:13:44.486450Z2026-05-07T10:13:54.236529Z2026-05-07T10:13:59.559230Z2026-05-07110:14:11.8091682tip: wire screenpipeclaude mcp adrthen askclau2026-05-07T10:15:45.2026-05-07110:15:45.2026-05-07T10:15:58.2026-05-07T10:15:58.2026-05-07T10:15:58.2026-05-07T10:16:052026-05-07T10:16:06.212026-05-07T10:16:10.088825Z2026-05-07T10:16:11.585397Z2026-05-07T10:16:11.626664Z2026-05-07T10:16:14.079057Z2026-05-07110:16:16.219212Z2026-05-07T10:16:16.238237Z2026-05-07T10:16:17.211409Z2026-05-07T10:16:17.247202Z2026-05-07T10:16:37.973759Z2026-05-07T10:16:38.014645Z2026-05-07T10:16:38.719453Z2026-05-07T10:16:38.757458Z2026-05-07T10:16:39.323203Z2026-05-07T10:16:39.361472Z2026-05-07110:16:40.850433Z2026-05-07T10:16:42.489832Z2026-05-07T10:16:44.044480Z2026-05-07T10:16:44.383786ZiTerm2ShellEditViewSessionScriptsProfilesWindowHelpSupport Daily • in 4 h 44 m100% C8Thu 7 May 10:16:46ffmpegO ₴1DEV (-zsh)• ₴2APP (-zsh)-zsh₴4ffmpegINFOscreenpipe_engine::event_driven_capture:contentdedup:skipping capturefor monitor 1 (hash=9173838423795606666,trigger=visual_change)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 1(hash=1669118135250037105,trigger=visual_change)INFOscreenpipe_engine::event_driven_capture: contentdedup:skippingcapture formonitor 1INFOscreenpipe_engine::event_driven_capture: contentdedup:skipping capturefor monitor 1Chash=1669118135250037105,trigger=visual_change)INFOscreenpipe_engine::event_driven_capture: contentskipping capture(hash=1669118135250037105,dedup:for monitortrigger=visual_change)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingforChash=1669118135250037105,capturemonitor 1 (hash=1669118135250037105,trigger=visual_change)trigger=visual_change)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 1 (hash=1669118135250037105,trigger=visual_change)INFOINFOscreenpipe_engine::event_driven_capture:contentdedup:skipping capture for monitor 1 (hash=1669118135250037105,screenpipe_engine::event_driven_capture: content dedup:skipping capture for monitor1 (hash=1669118135250037105,trigger=visual_change)INFOscreenpipe_engine::event_driven_capture: contentdedup:skippingcapture fortrigger=visual_change)monitor 1INFOscreenpipe_engine::event_driven_capture: contentdedup:skipping capturefor monitorChash=-6229566017341650404,trigger=click)1 (hash=-6229566017341650404,trigger=visual_change)INFOscreenpipe_engine::event__driven_capture: content dedup:skippingcapturefor monitor 1 Chash=-7077166956358270957,trigger=click)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapture formonitor 1 (hash=-3980541844315414876,INFOscreenpipe_engine::event_driven_capture:content dedup:trigger=visual_change)skippingcapture for monitor 1 (hash=6523625761174407917, trigger=click)INFOINFOINFOINFOINFOINFOINFOINFOINFOINFOINFOINFOINFOINFOINFOINFOINFOINFOlick)Lick3ne1al_change)Term-ick)engine::event_driven_capture:contentdedup:skippingcaptureformonitor 2 (hash=-6145754442538527174, trigger=click)engine: :event_driven_capture:contentdedup:skippingcapturefor monitor 1 (hash=-6145754442538527174, trigger=click)screenpipe_engine::event_driven_capture:contentdedup:skippingcaptureformonitor 2 (hash=-6145754442538527174, trigger=click)screenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 2(hash=806643008695069553, trigger=visual_change)screenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 2 (hash=806643008695069553,trigger=click)screenpipe_engine:: event_driven_capture:contentdedup:skippingcaptureforscreenpipe_engine:: event_driven_capture:contentdedup:skippingcaptureformonitor 1 (hash=806643008695069553,trigger=click)monitor 2 (hash=806643008695069553,trigger=click)screenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 1 (hash=806643008695069553,trigger=click)screenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 2 (hash=-8875948178524934281, trigger=click)screenpipe_engine::event_driven_capture: contentdedup:skippingcaptureformonitor 1 (hash=-8875948178524934281,trigger=click)screenpipe_engine::event_driven_capture: contentdedup:skippingcaptureformonitor 1(hash=-8875948178524934281,trigger=click)screenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor2screenpipe_engine:: event.driven_capture: contentdedup:skippingcaptureforChash=-8875948178524934281,trigger=click)monitor 2 (hash=-8875948178524934281,trigger=click)screenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 1 (hash=-8875948178524934281, trigger=click)screenpipe_engine::snapshot_compaction:snapshotcompaction:found 50eligibleframesscreenpipe_engine::snapshot_compaction:snapshotcompaction:25 frames,4.5MB→ 1.4MB (3.2x),25 JPEGSdeletedscreenpipe_engine::snapshot_compaction:snapshotcompaction:23 frames,4.2MB1.1MB (3.7x),23 JPEGSdeletedscreenpipe_engine::event_driven_capture:contentdedup: skipping capture for monitor 2 (hash=-8875948178524934281, trigger=visual_change)...
|
iTerm2
|
screenpipe"
|
NULL
|
|
DOCKER2026-05-07110:12:16.55057022026-05-07T10:12: DOCKER2026-05-07110:12:16.55057022026-05-07T10:12:31.745217Z2026-05-07T10:12:34.790862Z2026-05-07110:12:37.78475222026-05-07T10:12:40.806177Z2026-05-07T10:12:43.854881Z2026-05-07T10:12:59.015149Z2026-05-07T10:13:14.166750Z2026-05-07T10:13:17.184510Z2026-05-07T10:13:34.773468Z2026-05-07110:13:44.486450Z2026-05-07T10:13:54.236529Z2026-05-07T10:13:59.559230Z2026-05-07110:14:11.8091682tip: wirescreenpipeclaude mcp adrthen ask claur2026-05-07T10:15:45.2026-05-07110:15:45.2026-05-07T10:15:58.2026-05-07T10:15:58.2026-05-07T10:15:58.2026-05-07T10:16:052026-05-07T10:16:06.212026-05-07T10:16:10.088825Z2026-05-07T10:16:11.585397Z2026-05-07T10:16:11.626664Z2026-05-07T10:16:14.07905722026-05-07110:16:16.219212Z2026-05-07T10:16:16.238237Z2026-05-07T10:16:17.211409Z2026-05-07110:16:17.24720222026-05-07T10:16:37.973759Z2026-05-07T10:16:38.014645Z2026-05-07T10:16:38.719453Z2026-05-07T10:16:38.757458Z2026-05-07T10:16:39.323203Z2026-05-07T10:16:39.361472Z2026-05-07110:16:40.850433Z2026-05-07T10:16:42.489832Z2026-05-07T10:16:44.044480Z2026-05-07T10:16:44.383786ZiTerm2ShellEditViewSessionScriptsProfilesWindowHelpSupport Daily • in 4 h 43 m100% C8Thu 7 May 10:17:01screenpipe"O ₴1DEV (-zsh)• ₴2APP (-zsh)83-zsh₴4screenpipe"INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 1 (hash=9173838423795606666,trigger=visual_change)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 1INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor(hash=1669118135250037105,trigger=visual_change)monitor 1INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcaptureforChash=1669118135250037105,trigger=visual_change)monitor 1INFOscreenpipe_engine::event_driven_capture: contentskipping capture(hash=1669118135250037105,dedup:for monitortrigger=visual_change)Chash=1669118135250037105,trigger=visual_change)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcaptureformonitor 1 (hash=1669118135250037105,trigger=visual_change)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 1 (hash=1669118135250037105,trigger=visual_change)INFOscreenpipe_engine::event_driven_capture:contentdedup:skipping capturefor monitor 1 (hash=1669118135250037105,INFOscreenpipe_engine::event_driven_capture:contentdedup:skipping captureformonitor 1 (hash=1669118135250037105,trigger=visual_change)INFOscreenpipe_engine::event_driven_capture: contentdedup:skippingcaptureformonitor 1trigger=visual_change)trigger=click)INFOscreenpipe_engine::event_driven_capture: contentdedup:skippingChash=-6229566017341650404,capturefor monitor 1 (hash=-6229566017341650404,trigger=visual_change)INFOscreenpipe_engine::event_driven_capture: contentdedup:skippingcaptureforINFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcaptureformonitor 1 (hash=-7077166956358270957,trigger=click)monitor 1 (hash=-3980541844315414876,INFOscreenpipe_engine::event_driven_capture:content dedup:skippingcapturefortrigger=visual_change)monitor 1 (hash=6523625761174407917, trigger=click)3lick)Lick3ne1al_change)Finder-ick)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcaptureformonitor 2 (hash=-6145754442538527174, trigger=click)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 1 (hash=-6145754442538527174, trigger=click)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcaptureformonitor 2 (hash=-6145754442538527174, trigger=click)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcaptureformonitor 2(hash=806643008695069553, trigger=visual_change)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 2 (hash=806643008695069553,trigger=click)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcaptureformonitor 1 (hash=806643008695069553,trigger=click)INFOscreenpipe_engine:: event_driven_capture:contentdedup:skippingcaptureformonitor 2 (hash=806643008695069553,trigger=click)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 1 (hash=806643008695069553,trigger=click)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 2 (hash=-8875948178524934281, trigger=click)INFOscreenpipe_engine::event_driven_capture: contentdedup:skippingcaptureformonitor 1 (hash=-8875948178524934281,trigger=click)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcaptureformonitor 1(hash=-8875948178524934281,trigger=click)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcaptureformonitor2INFOscreenpipe_engine:: event_driven_capture: contentdedup:skippingcaptureforChash=-8875948178524934281,trigger=click)monitor 2 (hash=-8875948178524934281,trigger=click)INFOscreenpipe_engine::event_driven_capture:contentdedup:skippingcapturefor monitor 1 (hash=-8875948178524934281, trigger=click)INFOscreenpipe_engine::snapshot_compaction:snapshotcompaction:found 50eligibleframesINFOscreenpipe_engine::snapshot_compaction:snapshotcompaction:25 frames,INFOscreenpipe_engine::snapshot_compaction:snapshotcompaction:234.5MB→ 1.4MB (3.2x),25 JPEGSdeletedframes,4.2MB1.1MB (3.7x),23 JPEGSdeletedINFOscreenpipe_engine::event_driven_capture:contentdedup: skipping capture for monitor 2 (hash=-8875948178524934281, trigger=visual_change)...
|
iTerm2
|
NULL
|
NULL
|
|
DXP4800PLUS-B5F8
SlackFileEditViewGoHistoryWindowH DXP4800PLUS-B5F8
SlackFileEditViewGoHistoryWindowHelpDOCKERDOCKER (-zsh)₴81DEV (-zsh)O $2APP (-zsh)883EU ()-zshkibanaasticsearch"{"type" : "log""@timestamp": "2026-05-11T19:54:53Z","tags" : ["warning", "el,"data"], "pid" :7,'"message": "Unabletorevive connection: [URL_WITH_CREDENTIALS] : "2026-05-11T19:54:532",asticsearch", "data"],"pid":7,"message": "No livingconnections "}["warning"kibanaI {"type" : "log", "@timestamp" : "2026-05-11T19:54:53Z""tags" : ["warning"ugins""licensing"], "pid" :7,"message" : "License informationcould not be obtained from Elasticsearch due to Error: No Livingconnectionskibana1 {"type" : "log","@timestamp" : "2026-05-11T19:54:54Z", "tags" : ["error"ticsearch", "data"], "pid":7, "message" : "[ConnectionError]: getaddrinfo ENOTFOUND elasticsearch elasticsearch: 9200"}kibana1 {"type" : "log","@timestamp" : "2026-05-11T19:54:54Z", "tags" : ["warning", "elasticsearch", "data"], "pid" :7,"message":"Unable to revive connection: [URL_WITH_CREDENTIALS] "2026-05-11T19:54:54Z", "tags" : ["warning", "elasticsearch", "data"],"pid":7,"message"• "No livingconnections"}kibana1 {"type": "log","@timestamp": "2026-05-11T19:54:54Z","tags": ["error","plugins", "taskManager""taskManager"], "pid":7, "message": "Failed to poll for work: Error: NoLiving connections"}kibana1 {"type": "log", "@timestamp": "2026-05-11T19:54:57Z", "tags" : ["error", "elasticsearch".,"data"], "pid" :7, "message" :"[ConnectionError]: getaddrinfo ENOTFOUND elasticsearch elasticsearch:9200*}kibana1 {"type" : "Log","@timestamp" : "2026-05-11T19:54:57Z", "tags" : ["warning", "elasticsearch", "data"], "pid" :7, "message": "Unable to revive connection: [URL_WITH_CREDENTIALS] : "2026-05-11T19:54:57Z", "tags" : ["warning", "elasticsearch", "data"], "pid" :7, "message": "No living connections"}kibanaI {"type" : "log", "@timestamp" : "2026-05-11T19:54:57Z", "tags" : ["error"ins","taskManager", "taskManager"], "pid":7, "message": "Failed to poll for work: Error: NoLiving connections"}kibanaI {"type" : "log", "@timestamp" : "2026-05-11T19:54:59Z","tags" : ["error", "elasticsearch", "data"], "pid" :7, "message" : "[ConnectionError]: getaddrinfo ENOTFOUND elasticsearch elasticsearch:9200"}kibana1 {"type" : "log","@timestamp": "2026-05-11T19:55: 00Z","tags" : ["warning", "elasticsearch", "data"], "pid" :7, "message": "Unable to revive connection: [URL_WITH_CREDENTIALS] : "2026-05-11T19:55 :00Z", "tags" : ["warning", "elasticsearch", "data"], "pid" :7, "message": "No living connections"}1 {"type": "log", "@timestamp" : "2026-05-11T19:55:00Z""tags" : ["error", "plug, "taskManager",, "taskManager"], "pid" :7, "message": "Failed to poll for work: Error: NoLiving connections"}unexpected EOFikas@Lukas-Kovaliks-MacBook-Pro-Jiminny ~/jiminny/infrastructure/dev/docker (develop) $HomeDMsActivityFilesLaterMoreallSupport Daily • in 3h 12 m100% C8• Tue 12 May 11:48:57ED→Describe what you are looking forJiminny ...8 jiminny-x-integrati...platform-inner-team# Channels# ai-chapter# alerts# backend# bugs# confusion-clinic# curiosity_lab# engineering# general# jiminny-bg# platform-tickets# product_launches# random# releases# sofia-office# support# thank-yous# the_people_of jimi...Direct messagesR. Steliyan GeorgievPetko Kashinski. Galya Dimitrovae. Aneliya Angelova&. Stefka Stoyanova€. Vasil VasilevSteliyan Georgiev6 0MessagesAdd canvasO Files+лгидейта с на гнг да пего прооваме през час ноГаля попита за рToday~HEпредполагам че е нещо случайно най-вероятносамо един репортза бъдеще може да в самия пропхет има липроверка дали има всичко преди да върнеresponse, или пак от РНР да се провери предипращане и да се пусне отновоSteliyan Georgiev 10:51 AMможе да направя профет ако няма pdf_url, даврьща грешка за пхп?Lukas Kovalik 10:51 AMпо-скоро да се регенерираLukas Kovalik 11:48 AMето го и репортSELECT * FROM automated_report_results WHEREuuid_to_bin(' 822fa41b-afd3-43a9-a248-86b0e36f3131') = uuid;реално са два pdf и podcast и podcast си работибез проблемimage.png vkasMessage Steliyan Georgiev..•...
|
Firefox
|
Personal — Mozilla Firefox
|
NULL
|
|
DXP4800PLUS-B5F8
nas.lakylak.xyz
New Tab
New Tab
S DXP4800PLUS-B5F8
nas.lakylak.xyz
New Tab
New Tab
Screenpipe — Archive
Screenpipe — Archive
All docs · AFFiNE
All docs · AFFiNE
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
Close tab
New Tab...
|
Firefox
|
Personal — Mozilla Firefox
|
NULL
|
|
DXP4800PLUS-B5F8
nas.lakylak.xyz
New Tab
New Tab
S DXP4800PLUS-B5F8
nas.lakylak.xyz
New Tab
New Tab
Screenpipe — Archive
Screenpipe — Archive
All docs · AFFiNE
All docs · AFFiNE
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
Close tab
New Tab
New Tab
Close tab
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
22°
C
New York City
Open menu
Mozilla Firefox
Search with Google or enter address
Search with Google or enter address
Inbox - [EMAIL] - Gmail...
|
Firefox
|
Personal — Mozilla Firefox
|
NULL
|
|
Data Explorer
ws.planhat.com
New Tab
New Tab
Jy 20 Data Explorer
ws.planhat.com
New Tab
New Tab
Jy 20820 es reindex stream model hydration by Vasil-Jiminny · Pull Request #12059 · jiminny/app
Jy 20820 es reindex stream model hydration by Vasil-Jiminny · Pull Request #12059 · jiminny/app
[JY-20725] [HubSpot] Optimise CRM rematching on delete hubspot accounts/contacts - Jira
[JY-20725] [HubSpot] Optimise CRM rematching on delete hubspot accounts/contacts - Jira
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
Pipelines - jiminny/app
Pipelines - jiminny/app
Pull requests · jiminny/app
Pull requests · jiminny/app
[JY-20773] User Pilot not receiving events on report generated - Jira
[JY-20773] User Pilot not receiving events on report generated - Jira
JY-20773 fix user pilot tracking ofr automated report generated by LakyLak · Pull Request #12024 · jiminny/app
JY-20773 fix user pilot tracking ofr automated report generated by LakyLak · Pull Request #12024 · jiminny/app
[JY-20776] Automated report - sentry - Jira
[JY-20776] Automated report - sentry - Jira
TypeError: League\Flysystem\Filesystem::has(): Argument #1 ($location) must be of type string, null given, called in /home/jiminny/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php on line 218 — jiminny — app
TypeError: League\Flysystem\Filesystem::has(): Argument #1 ($location) must be of type string, null given, called in /home/jiminny/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php on line 218 — jiminny — app
TypeError: League\Flysystem\Filesystem::has(): Argument #1 ($location) must be of type string, null given, called in /home/jiminny/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php on line 218 — jiminny — app
TypeError: League\Flysystem\Filesystem::has(): Argument #1 ($location) must be of type string, null given, called in /home/jiminny/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php on line 218 — jiminny — app
Platform Sprint 3 Q2 - Platform Team - Scrum Board - Jira
Platform Sprint 3 Q2 - Platform Team - Scrum Board - Jira
JY-20625 | JY-20742 | MCP POC by yalokin-jiminny · Pull Request #12036 · jiminny/app
JY-20625 | JY-20742 | MCP POC by yalokin-jiminny · Pull Request #12036 · jiminny/app
LLM pricing overview with the most actual prices - Google Search
LLM pricing overview with the most actual prices - Google Search
Planhat
Planhat
Data Explorer
Data Explorer
Close tab
JY-20773 fix user pilot tracking ofr automated report generated by LakyLak · Pull Request #12024 · jiminny/app
JY-20773 fix user pilot tracking ofr automated report generated by LakyLak · Pull Request #12024 · jiminny/app
Close tab
New Tab
Customize sidebar
Close Google Gemini (⌃X)
Tabs from other devices
Open history (⇧⌘H)
Open bookmarks (⌘B)
AI Chat settings
Close
WORK, Google Account: [EMAIL]
Main menu
New Chat
Open menu for conversation actions.
Conversation with Gemini
Conversation with Gemini
Copy prompt
Edit
You said I am on [URL_WITH_CREDENTIALS] -4,10 +4,13 @@
4
4
5
namespace
Jiminny
\
Events
\
AutomatedReports
;
5
namespace
Jiminny
\
Events
\
AutomatedReports
;
6
6
7
+
use
Illuminate
\...
|
Firefox
|
JY-20773 fix user pilot tracking ofr automated rep JY-20773 fix user pilot tracking ofr automated report generated by LakyLak · Pull Request #12024 · jiminny/app — Work...
|
github.com/jiminny/app/pull/12024/changes
|
|
Data Explorer
ws.planhat.com
Unnamed Group
TypeErr Data Explorer
ws.planhat.com
Unnamed Group
TypeError: League\Flysystem\Filesystem::has(): Argument #1 ($location) must be of type string, null given, called in /home/jiminny/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php on line 218 — jiminny — app
TypeError: League\Flysystem\Filesystem::has(): Argument #1 ($location) must be of type string, null given, called in /home/jiminny/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php on line 218 — jiminny — app
CloudWatch | us-east-2
CloudWatch | us-east-2
[JY-20725] [HubSpot] Optimise CRM rematching on delete hubspot accounts/contacts - Jira
[JY-20725] [HubSpot] Optimise CRM rematching on delete hubspot accounts/contacts - Jira
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
[JY-20773] User Pilot not receiving events on report generated - Jira
[JY-20773] User Pilot not receiving events on report generated - Jira
JY-20773 fix user pilot tracking for automated report generated by LakyLak · Pull Request #12024 · jiminny/app
JY-20773 fix user pilot tracking for automated report generated by LakyLak · Pull Request #12024 · jiminny/app
JY-20625 | JY-20742 | MCP POC by yalokin-jiminny · Pull Request #12036 · jiminny/app
JY-20625 | JY-20742 | MCP POC by yalokin-jiminny · Pull Request #12036 · jiminny/app
Close tab
Data Explorer
Data Explorer
Close tab
[JY-20776] Automated report - sentry - Jira
[JY-20776] Automated report - sentry - Jira
Jiminny
Jiminny
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
[SRD-6793] Les Mills activity types not pulling in - Jira
[SRD-6793] Les Mills activity types not pulling in - Jira
Platform Team - Backlog - Jira
Platform Team - Backlog - Jira
[JY-20773] User Pilot not receiving events on report generated - Jira
[JY-20773] User Pilot not receiving events on report generated - Jira
JY-20773 fix user pilot tracking for automated report generated by LakyLak · Pull Request #12024 · jiminny/app
JY-20773 fix user pilot tracking for automated report generated by LakyLak · Pull Request #12024 · jiminny/app
Pipelines - jiminny/app
Pipelines - jiminny/app
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Tabs from other devices
Open history (⇧⌘H)
Open bookmarks (⌘B)
Skip to content
Skip to content
Open menu
Homepage (g then d)
jiminny
jiminny
app
app
Search or jump to…
Type
/
to search
Chat with Copilot
Open Copilot…
Create new...
All issues(g then i)
All pull requests
All repositories
You have unread notifications(g then n)
Open user navigation menu
Repository navigation
Repository navigation
Code
Code
Pull requests (34)
Pull requests
(
34
)
Agents
Agents
Actions
Actions
Wiki
Wiki
Security and quality (4)
Security and quality
(
4
)
Insights
Insights
Settings
Settings
Important update...
|
Firefox
|
JY-20625 | JY-20742 | MCP POC by yalokin-jiminny · JY-20625 | JY-20742 | MCP POC by yalokin-jiminny · Pull Request #12036 · jiminny/app — Work...
|
github.com/jiminny/app/pull/12036/changes
|
|
Data Explorer
ws.planhat.com
Unnamed Group
TypeErr Data Explorer
ws.planhat.com
Unnamed Group
TypeError: League\Flysystem\Filesystem::has(): Argument #1 ($location) must be of type string, null given, called in /home/jiminny/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php on line 218 — jiminny — app
TypeError: League\Flysystem\Filesystem::has(): Argument #1 ($location) must be of type string, null given, called in /home/jiminny/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php on line 218 — jiminny — app
CloudWatch | us-east-2
CloudWatch | us-east-2
[JY-20725] [HubSpot] Optimise CRM rematching on delete hubspot accounts/contacts - Jira
[JY-20725] [HubSpot] Optimise CRM rematching on delete hubspot accounts/contacts - Jira
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
[JY-20773] User Pilot not receiving events on report generated - Jira
[JY-20773] User Pilot not receiving events on report generated - Jira
JY-20773 fix user pilot tracking for automated report generated by LakyLak · Pull Request #12024 · jiminny/app
JY-20773 fix user pilot tracking for automated report generated by LakyLak · Pull Request #12024 · jiminny/app
JY-20625 | JY-20742 | MCP POC by yalokin-jiminny · Pull Request #12036 · jiminny/app
JY-20625 | JY-20742 | MCP POC by yalokin-jiminny · Pull Request #12036 · jiminny/app
Close tab
Data Explorer
Data Explorer
Close tab
[JY-20776] Automated report - sentry - Jira
[JY-20776] Automated report - sentry - Jira
Jiminny
Jiminny
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
[SRD-6793] Les Mills activity types not pulling in - Jira
[SRD-6793] Les Mills activity types not pulling in - Jira
Platform Team - Backlog - Jira
Platform Team - Backlog - Jira
[JY-20773] User Pilot not receiving events on report generated - Jira
[JY-20773] User Pilot not receiving events on report generated - Jira
JY-20773 fix user pilot tracking for automated report generated by LakyLak · Pull Request #12024 · jiminny/app
JY-20773 fix user pilot tracking for automated report generated by LakyLak · Pull Request #12024 · jiminny/app
Pipelines - jiminny/app
Pipelines - jiminny/app
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
JY-20725 add HS rate limit handling on activities rematching by LakyLak · Pull Request #12066 · jiminny/app
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Tabs from other devices
Open history (⇧⌘H)
Open bookmarks (⌘B)
Skip to content
Skip to content
Open menu
Homepage (g then d)
jiminny
jiminny
app
app
Search or jump to…
Type
/
to search
Chat with Copilot
Open Copilot…
Create new...
All issues(g then i)
All pull requests
All repositories
You have unread notifications(g then n)
Open user navigation menu
Repository navigation
Repository navigation
Code
Code
Pull requests (34)
Pull requests
(
34
)
Agents
Agents
Actions
Actions
Wiki
Wiki
Security and quality (4)
Security and quality
(
4
)
Insights
Insights
Settings
Settings
Important update
Important update
On April 24 we'll start using GitHub Copilot interaction data for AI model training unless you opt out.
Review this update
Review this update
and manage your preferences in your
GitHub account settings
GitHub account settings
.
Dismiss banner
JY-20625 | JY-20742 | MCP POC #12036 Edit title
JY-20625 | JY-20742 | MCP POC
#
12036
Edit title
Preview
Preview
Checks pending
Checks pending
Code
Code
Open
yalokin-jiminny
yalokin-jiminny
wants to merge 32 commits into
master
master
from
JY-20742-mcp-poc
JY-20742-mcp-poc
Copy head branch name to clipboard
Lines changed: 1680 additions & 1 deletion...
|
Firefox
|
JY-20625 | JY-20742 | MCP POC by yalokin-jiminny · JY-20625 | JY-20742 | MCP POC by yalokin-jiminny · Pull Request #12036 · jiminny/app — Work...
|
github.com/jiminny/app/pull/12036/changes
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Fir Diff
Changelist:
Changelist:
Changes
Show Diff
Firefox FileEditViewHistoryBookmarksProfilesToolsWindowHelp<DEV (docker)• жз• Support Daily - in 4h 53 mDOCKER₴1DEV (docker)882APP (-zsh)masterJY-20818-move-AJ-reports-to-separated-datadog-metricJY-20773-fix-automated-reports-user-pilot-trackingJY-20157-AJ-report-not-send-notificationJY-20508-notify-before-AJ-report-expirationJY-20372-ai-reports-promotion-pagesJY-20352-sync-opportunities-without-a-local-owner-user-id-is-nullJY-20738-debug-AJ-tracking-UPJY-18909-automated-reports-ask-jiminnyJY-20692-fix-integration-app-[API_KEY]@Lukas-Kovaliks-MacBook-Pro-Jiminny ~/jiminny/app (JY-20725-handle-HS-search-rate-limit) $ devroot@docker_lamp_1:/home/jiminny# ]-zsh84-zsh885100% C8• Mon 11 May 10:07:091881screenpipe"O 86DEV...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
PhostormVIewavigateCodeLaravelKeractorWindowmelp°9 JY-20725-handle-HS-search-rateProleteyC) TrackAutomated ReportGeneratedzventonp© UserAutomatedReportsController.php© BatchSyncCollectolT SyncCrmEntitiesTrait.phpC) CachedCrmServiceDecorator.ongJiminnyDeougcommana.ongT DeleteCrmEntityTrait.phpe balchsynckealsse© CheckAndRetryRemoteMatch.php© ClosedDealStagesS © RateLimitException.phpDealrielasservice.gc)Decorateacuivilv.or© FieldDefinitions.phrclass Cllent extends Baseclient 1mpLements Hubspo• M Exceptions 1 fileC) FieldT vpeconvertepublic const string BASE_URL = 'https:lapi.RateLimitException.phpe HubspotclientinterV W Jobs 2 filesc) Hubspot lokenmanC) PavloadBuilder.phppublic const int ASSOCIATIONS_BATCH_SIZE_LIMIv Crm 1 file3 added 6 modifiedC) RemotecrmobiectrP ResponseNormalizeZusagesCommit Messagec) Service.onrprivate HubspotPaginationService Spaginationreorder callsC)SvncFieldAction.onZusagesC) SvncRelatedActivitprivate HubspotTokenManager $tokenManagerC) WebhookSvncBatclv MintearationAor49 đpublic function -_constructlM AcceccorsSoc1aLAccountservice ssoc1alAccountserV1cv DiftHubspotPaginationService SpaginationServiI/¢→8Side-by-side viewerDo not ignoreLocal ChangesCancola yLog X8 35f036acy dectarelstrdct-lypes-t)rChanaes 12 files= env.local aor.8 35f036ac app/Senamesnace liminnv Fxcentions.C) Client.oho aon/Services/Crm/Hubsoot© HandleHubspotRateLimit.php app/Jobs/MiddlewareC HandleHubspotRateLimitTest.php tests/Unit/Jobs/Middleware© HubspotClientinterface.php app/Services/Crm/Hubspot© HubspotPaginationService.php app/Services/Crm/Hubspot/Pagination© JiminnyDebugCommand.php app/Console/CommandsUse Hubspot ll1class RateLimitException extends LogicExceptionUse Hubspot ll1use Hubspot ibisuse Jaminny x0use Jaminny Excphp logging.php configuse Jiminny or© MatchActivityCrmData.php app/Jobs/Crmuse Jiminny Mod© PaginationState.php app/Services/Crm/Hubspot/PaginationRateLimitException.php app/Exceptions© RateLimitExceptionTest.php tests/Unit/Exceptionsuse Jiminny Seruse SevenShoresUnversioned Files 9 filesuse SevenShones Hubsnot Factory:E.env.nikilocal appSevenShores Hubsnot Httn Resnonse:E.env.other appuse Jiminny\Services\Crm \Hubspot \Pagination \HubspotPaginationService:© CanAccessAiReportsTest.php tests/Unit/Policiesuse Throwable:© CreateMockAskJiminnyReportResultCommand.php app/Console/Commands/Rnravicon.ico puolic=ids.txt a0d* @phpstan-tupe CrmFieldOption arrayfid:string, label:string, value?:string}1araw sal querv sal aool@ SimulateWebhooksCommand.ohn app/Console/Commands/Crm/HubspotCthic-scotRacolin1(colf.•RASE HIPI).M. WEBHOOK FILTERING IMPLEMENTATION.mdaoo.Sthis->setVersion(self::MIN_API_VERSION):public function getMinimumApiVersion(: stringreturn selt::MIN API VEKSTON:C) Hubspot/Service.onp(c) HubSpot/Service.onpoveryaetviycrmlaskJoo.phpc) RateLimitExceptionlest.onp© CrmActivityService.phpCommit ChanaesChangelist:ChangesAuthor:Amend commitSian-off commitCommit checksUpdate copvriahiPoformat codeRearrange codeOpuimize imporisHighlight worasculrent versiondeclare(strict_types=1);namesnace Liminnv Fycentions.use Throwahle-Lomerencesclass RateLimitException extends RuntimeExceptiorpublic function __construct(private readonly int SretryAfter = 1.CancelCommitPreparation for Refi... 25 m left100% 1Mon 11 May 15:35:53=laravel.log *4 SF (jiminny@localhost]4 HS_local [jiminny@localhost]* console PROD1& console lEUllA console [STAGING]429W.*2026-05-11 11•21•451 1ocol TNS0• THuhSnot lounnal Pollinal No datafwponnelation #au.1054d156d_Ra4f-4500-2046-e16e5ddTdZhfi ltnace #du-HlencTachS-ahef m226-05-11 11:21:45] LocaZ.WARNTNG: [HubSpot Journal Polling) Maximum empty results reached, stopping {"empty_results":5, "nax empty-results":5} ("correlation. D14O-UOF1YAN40 LUCULVARwOhoospot Jourat pocenenraxemon empuytesuces teacheur scoppanememstyNesucusmenmaX emguy_results":5} {"correlation w926-05-11 11:21:45] local.INF0: [HubSpot Journal Pollingl Service ending {"runtime_seconds":57,"total_cycles":5,"files_downloaded":0,"empty_files":0,"other_926-05-11 11:21:46] local.INF0: [HubSpot Journal Pollingl Saved offset to database on cleanup {"offset":"019e15a9-9ea0-7da7-87bc-82592e3ccf0d"} {"correlatio20-05-11 11.21.40 LoCaL.INFU. LHUDSpot JournaL PoLLing keLeased poLLing lock1"correlation_1d: У5401500-8a4t-4572-a040-elocsad/as0t,"trace_1d": "ecc/ael926-05-11 11:21:48] local.INF0: Jiminny\Console\Commands\Command::run Memory usage before starting command {"command":"mailbox:batch:process", "memoryBeforeC126-05-11 11:21:48 LocaL.INFU: Emallschedule STAKlING bacch processockerLamp1" 1 "correlacion 10": 2414210e-/45e-44a5-a05t-5//010502410C126-05-11 11:21.48 LocaL.INrU: cmanuschedulel rinishcu bacchl126-05-11 11:21:48 LocaL.LNFU:Jiminny console Lonmoryberorecommanolnmd926-05-11 11:21:59] local.INFO: Jiminny\Console\Commands\Command: :run Memory usage before starting command {"command" : "crm: sync-hubspot-objects", "memoryBef]26-05-11 11:22:001 Local.INF0:Jiminny Console commands Conmand::run Memory usage for command "command": "crm:sync-hubspot-obnects", "memoryBeforecommandinMi926-05-11 11:22:00] Local.INFO: [SyncHubspot0bjects] Starting sync {"team": "b2b115eb-93ce-4d1b-929c-173757df8fba", "usage": 23350336, "real_usage" :62914560 , "pit26-05-11 11:22:001 Local.WARNING:Hubspot Account not connected for user luserd': 55es4ara-1002-4104-87aс-22c5as85ebes", "account"AWAminny Wodel sASo326-05-11 11:22:001 Local.INFU: LCrmOwnerResolverJ Integration owner is not connected, attempting team members ?"crm_provider": "hubspot", "crm_owner":109, "te16-05-11 11:22:001 LocoL INF0: crmownerResolverNo team members Found with active erm connection "erm providen"*"hubspot""team 1d":2% "correlation 1d26-05-11 11:22:001 Loc0L.INE0:CrmOwnerResolver]No team member found with active crm connection {"crm_provider": "hubspot", "team_id":29} {"correlation_id"26-05-11 11:22:00] local.INFO: [SyncHubspot0bjects] Sync finished {"team":"b2b115eb-93ce-4d1b-929c-173757df8fba", "provider":"hubspot","status":"disconnecter4 differencescurrent versionuse HubSpot\ Client\Crm\Pipelines Model\PipelineStage:use Hubspot Lllent Crm Properties Model Propertyuse HubSpot\Discovery\Discovery:use Jaminny xceotions Crmexcentzon:Jiminny\Exceptions\RateLimitExceptionuse Jiminny Exceotions SocialAccountTokenInval1dExceotion:use Jiminny\Jobs\Crm\Note0bject;use Jiminny Models Crm Field:use JiminnyServices\Crm\BaseClient;luse SevenShones|Hubsnot\Eycentions|HubsnotEycention.use SevenShores Hubsnot Factory:use SevenShores\Hubspot\Http\Response;use Jiminnv Services Crm Hubsnot Pagination HubsnotPaginationService:use Tlluminate| Sunnont| Facades| Pedis:luce Thnowahle./*** @phpstan-tupe CrmFieldOption array{id:string, label:string, value?:string}Sthis->setBaseUrl(self::BASE_URL):Sthis->setVersion(self::MIN_API_VERSION) :»* Execute a HubSoot APT call with rate limit handlina.fo 4 spaces...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
1 modified
JY-20725 add more tests
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
PhostormcodeHelpers_ huospotC) UserAutomatedReportscontroller.png_ ActionsODTO© MatchActivityCrmData.phpCrmactivityservice.png olu rielosW Journal0 OpportunitySyncStrateccLassseererest extenuselestease ceot1/ --------v _ Pagination© HubspotPaginationSe 100gc) PaginationContiatesc) PacinationStateliest.pubuic tunccion testsearchlhrowskaceL1micexcProspectSearchStrateg)M ServiceTraits1849 %Webhool@ BatchSvncCollectorTest 187pubLic tunccion testsearchlhrowskaceL1m1cexce1880 %C) BatchSvncRedisServiceoubuic tunction restsearchrropagaresnonkarelc) ClientTest.oho( ClosedDea|StadesServic 11C DealFieldsServiceTest.p( Decorate ActivitvTest nh 192CancalaLocal ChangesChanaes 4 files= env.local ano(c) ClientTest.oho tests/Unit/Services/Crm/Hubsooti© JiminnyDebugCommand.php app/Console/Commandsphp logging.php config• v Unversioned Files 9 filesE.env.nikilocal app=env other annl(8 CanAccessAiReportsTest.php tests/Unit/Policies© CreateMockAskJiminnyReportResultCommand.php app/Console/Commands/ReE favicon.ico publicE ids.txt appT raw sal_query.sal app© SimulateWebhooksCommand.php app/Console/Commands/Crm/Hubspolm+ WEBHOOK_FILTErING_IMPLEMEnTATION.md appMon 11 May 17:30:01v tests/Unit/Services/Crm/Hubsoot 1 file© ClientTest.php= env.localUnversioned Files 9 filesCommit MessageJY-20725 add more testsv DiftI@¢→Do notignore@cbed2c9a tesJuse HubSpot\Client\Crm\Associations\Api\BatchApi;use HuhSnot Client Crm Associations ModelRatchTnnutAchod2nQn toctchl-use HubSpot \Client\Crm\Associations \Model\BatchRespouse HuhSnot Client Crm Accociations ModelPuhlichhie_use HubSpot \Client\Crm Deals\Api \BasicApi as DealsBaUse Hubspot ll1use HuhSnot Client Crm. Nealc Model SimnlePuhlichhieruse ubsootc-use HubSpot \Client\Crm\Pipelines\Api\PipelinesApi;- use Huosoot cuuco HubSnot Mion+ Crm. Dinolinoc Modol CollostionDoc-use HubSpot\Client\Crm\Pipelines\Model\Erroruse Hubspot chuse Hubspot Cllent Crm Properties Ap1 CoreAp1use Hubspot cuuse HubSpot \Client\Crm\Properties \Api\CoreApi,use HubSpot\Client\Crm\Properties\Model \Property:use HubSpot\Discovery as HubSpotDiscovery:use HubSpot\Discovery \Crm\Deals \Discovery as DealsDiscovery:use Jiminny Models\Crm\Configuration;uco liminnv Modole Com. Ciold.- use Jiminny Models\SocialAccount;uco liminnvlSonvicoc|Cnml Hubenot|Client.use Jiminny Services\Crm Hubspot \HubspotTokenManager:use Jiminny\Services\Crm Hubspot \Pagination HubspotPaginationService:Use Jiminny services soc1alAccountservice*use Leaque OAuth2 Client Token AcceccTokoneuse PHPUnit\Framework\Mock0bject \Mock0biect:use PHPUnit\Framework\ TestCase:Psr Loo nulcloggersevenshores huospor nopoints cnoagementsRematchActivityOnCrmObjectDetach.php© HubspotPaginationService.phpC) TrackAutomatedRenortGeneratedFvent.nhnlhuospot/serwice.pnpT SyncCrmEntitiesTrait.phpC) CachedCrmServiceDecorator.ongCommit ChanaesChangelist:ChangesAuthorAmend commitSian-off commitCommit checksUodate copvrighiReformat codeRearrange codeOpuimize imporisHighlight woraso omerencesCurrent versionuse HubSpot \Client \Crm \Associations\Api\BatchApi; Ause HubSpot \Client\Crm \Associations \Model\BatchInpütuse HubSpot \Client\Crm \Associations\Model\BatchRes:use Hubspot Client Crm Associations Modell Public0huse HubSpot \Client\Crm \Companies \ApiException as Cuse hubspot Client Crm. Contacts An:Excention ac Couse HubSpot \Client\Crm \Deals\Api \BasicApi as Dealsuse HubSpot \Client\Crm \Deals\ApiException as DealAuse HubSpot\Client\Crm\Deals\Model\SimplePublic0bieuco HnhSno+l Ciiontl Coml DinolinoclAndl pinolinocans.use HubSpot\ Client\ Crm\Pipelines Model\ CollectionRCance=laravel.log *A SF [jiminny@localhost]4 HS_local [jiminny@localhost]console [pRODlA console (EullA console [STAGING]w.*12026-05-11 11•21•451 1ocol TNS0• THuhSnot lounnal Pollinal No data{"correlation_id": "954d156d-8a4f-4592-a046-e16c5dd7d3bf™, "trace_id" : "ecc7aeb5-a4e6 "?926-05-11 11:21:45] local.WARNING: [HubSpot Journal Polling) Maximum empty results reached, stopping {"empty_results":5,"max_empty_results":5} {"correlation926-05-11 11:21:45] local.WARNING: [HubSpot Journal Polling] Maximum empty results reached, stopping {"empty_results":5,"max_empty_results":5} {"correlation926-05-11 11:21:45] local.INF0: [HubSpot Journal Polling] Service ending {"runtime_seconds":57,"total _cycles":5,"files_downloaded":0,"empty_ files":0,"other926-05-11 11:21:46] Local.INFO: [HubSpot Journal Polling] Saved offset to database on cleanup {"offset": "019e15a9-9ea0-7da7-87bc-82592e3ccf0d"} {"correlatiol20-05-11 11.21.40 LoCaL.INFU. LHUDSpot JournaL PoLLing keLeased poLLing lock{"correlation_id":"954d156d-8a4f-4592-a046-e16c5dd7d3bf" "trace_id":"ecc7a140-05-111H41H48 LOCULWRUH JInhYA vonso Len conmanas Connano hrun remory usage berore stancine conmand econnanoиnасрохнрасслнNO126-05-11 11:21:48 LocaL.INFU: Emaltschedule STAKlING bacch process026-05-11 11:21:481 local.INF0: [EmailSchedulel FINISHED batch26-05-11 11:21:48 LocaL.LNrU: Jaminny Lonsole commanos commano..run026-05-11 11:21:591 local.INF0: Jiminny\Console\ ComnMemory usage befone starting comnand ("connand","ern:syne-hubspot-objects", "memoryße fesnmand" . "crm:sync-hubspot-obiects" "memoryBeforeCommandIrim26-05-11 11:22:001 Local.INF0:026-05-11 11:22:001 local.INF0: [SyncHubspot0biects] Starting syncИ05-ИИIRНAOCO RVARIEHUOSDOtAccount not connectedor Usen E wusen GiP"sSesLaVAs CoyE4oLVACEoeC assseesP laC Count teAm inhyA NVionel SII326-05-11 11:22:00J Local.INFO: LCrmOwnerResolverJ Integration owner is not connected, attempting team members 1"crm_provider": "hubspot", "crm_owner":109,'16-05-11 11:22:001 LocoL INF0: crmownerResolverNo team members found with active crm connection {"crm providen" "hubspot" "team id".29} {"correlation jd26-05-11 11:22:001 1oc0L,1NE0:CrmOwnerResolver]]member found with active erm connection {"erm providen"."hubspot" "team id".29} {"correlation iom26-05-11 11:22:001 local, INF0: [SvncHubspot0biectsl Svnc finished {"team"."b2b115eb-93ce-4d1b-929c-173757df8fba" "providen"."hubspot" "status". "disconnecte6 differencescurrent versionuse HubSpot\Client\Crm Associations\Api\BatchApi:Hubspot Cllent Crm Assoclations Model BatchlnputPubl1cubnectlduse HubSpot\Client\Crm\Associations\Model\BatchResponsePublicAssociationMultisuse iubspot cent Crm Associations Model Puouicuonectduse HubSpot\Client\Crm\Companies\ApiException as CompanyApiException;use Hubsoot cuient Crm Contacts ApiExcention as ContactAoiExcentionsuse HubSpot\Client\Crm\Deals\Api\BasicApi as DealsBasicApi;HubSoot Cuient Crm Deals ApiExcentionuse HubSpot\Client\Crm\Deals\Model\SimplePublic0bjectWithAssoCiations as DealWithAssociations;use HubSnot euient erm Pinelines Ant Pinellinesaniuse HubSpot\Client\Crm\Pipelines\Model\CollectionResponsePipeline;use HubSnot Client Com Pinelines Model Erron:use HubSpot\Client\Crm\Properties \Api \CoreApi;use HubSpot \Client\Crm \Properties \Model\Property:use HubSpot Discovery as HubSpotDiscovery:use HubSpot \Discovery \Crm \Deals Discovery as DealsDiscovery:uce liminnvl Gycontione|Patol imi+fycontion•use Jiminny \Models\Crm\Configuration:use Jiminny Models\Crm\Field:use Jiminny Models\SocialAccount:uco liminnv|Sonvicoc|CnmlHubeno+lCijen+.use Jiminny|Services\Crm Hubspot\HubspotTokenManager:use Jiminny Services\ Crm Hubspot\Paqination HubspotPaqinationService:use Jiminnv|Services|SocialAccountService:use Leaque\OAuth2\Client\ Token\AccessToken:fo 4 spaces...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
1 modified
JY-20725 add more tests
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
iTerm2ShellEditViewSessionScriptsProfilesWindowHelpAPP (docker)APP (docker)-zsh++DOCKER-232,9 +235,110 81DEV (docker)₴284* @param string SobjectType The object type ('deals', 'companies', 'contacts', 'calls')* @param array<string, mixed› Spayload The search payload with filters, sorts, properties, etc.ereturn array Thesearch response with'results'total', 'paging'keys* @throws RateLimitException When rate limit is hit* @throws HubspotException On API errors* @return array The search response with 'results', 'total','paging' keys*/public function search(string SobjectType, array Spayload): array-zsh> 0 Ilol*5screenpipe"100% <78• Mon 11 May 17:30:01181O 886-zsh*7 |+APPend diff4) app/Console/Commands/JiminnyDebugCommand.php (statement_indentation)begin diff--- /home/jiminny/app/Console/Commands/JiminnyDebugCommand.php+++/home/jiminny/app/Console/Commands/JiminnyDebugCommand.php-359,11 +359,11 @ScrmService = ScrmResolver->prepareCrmService();-//-//for (Si = 0; si < 3; Si++) {if (Si%25 ===0) {Sthis->info("Syncing opportunity {$1}");Sthis->info("Matching contact {$i}");-//-//.ScrmService->syncOpportunity('374720564');if ($i % 25 === 0) {Sthis->info("Syncing opportunity {$1}");Sthis->info("Matching contact {Si}");////ScrmService-›syncOpportunity('374720564');ScrmService-›matchByName('Robot');end diffFixed 4 of 5666 files in 146.870 seconds, 60.00 MB memory usedWhat's next:Try Docker Debug for seamless, persistent debugging tools in any container or image → docker debug docker_lamp_1...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
1 modified
Move non paginator search calls to client->search
Commit Message
Commit Message History
Previous Difference
Next Difference
Jump to Source...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
1 modified
Move non paginator search calls to client->search
Commit Message
Commit Message History
Previous Difference
Next Difference
Jump to Source
Compare Previous File...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
11 files, folder partially checked
app 9 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
Jobs 3 files, folder checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Services/Crm/Hubspot 4 files, folder checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
config 1 file, folder not checked
.env.local not checked
app 9 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
Jobs 3 files, folder checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Services/Crm/Hubspot 4 files, folder checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
RateLimitException.php, exception class checked
Jobs 3 files, folder checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
HandleHubspotRateLimit.php, class checked
Services/Crm/Hubspot 4 files, folder checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
config 1 file, folder not checked
.env.local not checked
1 added 7 modified
A
Commit Message
Commit Message History
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
2 differences
12295204
<?php
declare(strict_types=1);
namespace Jiminny\Exceptions;
class RateLimitException extends LogicException
{
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Exceptions;
use Throwable;
class RateLimitException extends LogicException
{
public function __construct(
string $message = '',
private readonly int $retryAfter = 1,
?Throwable $previous = null,
) {
parent::__construct($message, 0, $previous);
}
public function getRetryAfter(): int
{
return max($this->retryAfter, 1);
}
}
Help
Cancel
Shelve Changes...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
11 files, folder partially checked
app 9 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
Jobs 3 files, folder checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Services/Crm/Hubspot 4 files, folder checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
config 1 file, folder not checked
.env.local not checked
app 9 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
Jobs 3 files, folder checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Services/Crm/Hubspot 4 files, folder checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
RateLimitException.php, exception class checked
Jobs 3 files, folder checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
HandleHubspotRateLimit.php, class checked
Services/Crm/Hubspot 4 files, folder checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
config 1 file, folder not checked
.env.local not checked
1 added 7 modified
JY-20818 move ask jiminny reports to its own datadog metric
Commit Message
Commit Message History
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
2 differences
12295204
<?php
declare(strict_types=1);
namespace Jiminny\Exceptions;
class RateLimitException extends LogicException
{
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Exceptions;
use Throwable;
class RateLimitException extends LogicException
{
public function __construct(
string $message = '',
private readonly int $retryAfter = 1,
?Throwable $previous = null,
) {
parent::__construct($message, 0, $previous);
}
public function getRetryAfter(): int
{
return max($this->retryAfter, 1);
}
}...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
11 files, folder partially checked
app 9 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
Jobs 3 files, folder checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Services/Crm/Hubspot 4 files, folder checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
config 1 file, folder not checked
.env.local not checked
app 9 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
Jobs 3 files, folder checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Services/Crm/Hubspot 4 files, folder checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
RateLimitException.php, exception class checked
Jobs 3 files, folder checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
MatchCrmData.php, class checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
HandleHubspotRateLimit.php, class checked
Services/Crm/Hubspot 4 files, folder checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
Pagination 2 files, folder checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
HubspotPaginationService.php, class checked
PaginationState.php, class checked
Client.php, class checked
HubspotClientInterface.php, interface checked
config 1 file, folder not checked
.env.local not checked
1 added 7 modified
JY-20818 move ask jiminny reports to its own datadog metric
Commit Message
Commit Message History
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
2 differences
12295204
<?php
declare(strict_types=1);
namespace Jiminny\Exceptions;
class RateLimitException extends LogicException
{
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Exceptions;
use Throwable;
class RateLimitException extends LogicException
{
public function __construct(
string $message = '',
private readonly int $retryAfter = 1,
?Throwable $previous = null,
) {
parent::__construct($message, 0, $previous);
}
public function getRetryAfter(): int
{
return max($this->retryAfter, 1);
}
}
Help
Cancel
Shelve Changes
Shelve Changes...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
11 files, folder partially checked
app 9 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder partially checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder not checked
Middleware 1 file, folder not checked
Services/Crm/Hubspot 4 files, folder not checked
config 1 file, folder not checked
.env.local not checked
app 9 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder partially checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder not checked
Middleware 1 file, folder not checked
Services/Crm/Hubspot 4 files, folder not checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder partially checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder not checked
Middleware 1 file, folder not checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
MatchCrmData.php, class checked
Crm 1 file, folder not checked
Middleware 1 file, folder not checked
Services/Crm/Hubspot 4 files, folder not checked
config 1 file, folder not checked
.env.local not checked
1 modified
Move non paginator search calls to client->search
Commit Message
Commit Message History
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
2 differences
35f036ac
<?php
declare(strict_types=1);
namespace Jiminny\Jobs\Activity\Import;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Events\Dispatcher;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Jiminny\Component\Queue\Constants;
use Jiminny\Component\Utility\Service\ProviderRateLimiter;
use Jiminny\Contracts\Services\Crm\ServiceInterface;
use Jiminny\DTO\ImportCall\Call;
use Jiminny\Component\TranscriptionSummary\Events\TranscriptionAiSummaryReadyEvent;
use Jiminny\Events\Activities\AiAutomation\ActivityProspectAdded;
use Jiminny\Exceptions\SocialAccountTokenInvalidException;
use Jiminny\Models\Activity;
use Jiminny\Models\Participant;
use Jiminny\Models\Team;
use Jiminny\Repositories\ActivityRepository;
use Jiminny\Services\Crm\CrmObjectsResolver;
use Jiminny\Services\Crm\ProspectSearchStrategyFactory;
use Jiminny\Services\Crm\ProviderRegistry;
use Psr\Log\LoggerInterface;
class MatchCrmData implements ShouldQueue
{
use Dispatchable;
use InteractsWithQueue;
use Queueable;
// AWS visibility timeout allows a maximum of 12 hours. This is 1 minute less.
private const int MAX_DELAY = 43140;
// Infrastructure allows max 3 retries (1 initial execution + 3 retries)
public int $tries = 4;
private Call $call;
private int $activityId;
private Team $team;
private ServiceInterface $crmService;
private LoggerInterface $logger;
private array $logContext;
public function __construct(Call $call, int $activityId)
{
$this->call = $call;
$this->activityId = $activityId;
$this->logContext = [
'activity_id' => $activityId,
'call_id' => $call->getCallId(),
'provider' => $call->getProvider(),
];
$this->onQueue(Constants::QUEUE_DIALERS);
}
public function handle(
CrmObjectsResolver $crmObjectsResolver,
ProviderRegistry $providerRegistry,
ProviderRateLimiter $rateLimiter,
ActivityRepository $activityRepository,
LoggerInterface $logger,
Dispatcher $eventDispatcher,
): void {
$this->logger = $logger;
// Activity is already augmented with CRM data, no need to perform the same operation
if ($this->call->isActivityUpdatedWithCrm()) {
$this->logMessage('Skipping activity. Already updated with CRM data');
return;
}
/** @var Activity $activity */
$activity = $activityRepository->findById($this->activityId);
try {
$this->initialiseCrmService($activity, $providerRegistry);
} catch (SocialAccountTokenInvalidException $exception) {
$this->logMessage('Invalid token, retrying');
$this->release(self::MAX_DELAY); // Try again tomorrow
return;
}
$prospectSearchStrategy = ProspectSearchStrategyFactory::match($this->team);
if ($prospectSearchStrategy->ignoreCrmMatchData()) {
// Ignore any associated opportunity
$this->logger->info('[MatchCrmData] Ignoring crm data because of prospect strategy', [
'activity_id' => $this->activityId,
'strategy' => get_class($prospectSearchStrategy),
]);
return;
}
if (! $rateLimiter->canMakeRequest($activity->getCrm())) {
$this->logMessage('Rate limit reached, retrying');
$this->release($rateLimiter->requestAvailableIn($activity->getCrm()) + random_int(1, 60));
return;
}
$this->logMessage('Resolving CRM objects');
$rateLimiter->incrementRequestCount($activity->getCrm());
$crmObjects = $crmObjectsResolver->resolveFromCall($this->crmService, $this->call);
if (empty($crmObjects)) {
$this->logMessage('Could not resolve CRM objects, retrying');
$this->release(3600);
return;
}
[$lead, $account, $opportunity, $contact, $stage] = $crmObjects;
$activity->update([
'lead_id' => $lead->id ?? null,
'contact_id' => $contact->id ?? null,
'account_id' => $account->id ?? null,
'opportunity_id' => $opportunity->id ?? null,
'stage_id' => $stage->id ?? null,
]);
$activity->refresh();
$eventDispatcher->dispatch(new ActivityProspectAdded(
activity: $activity,
eventSource: 'match-crm-data'
));
if ($activity->getProspectName() !== null) {
$activity->setTitleFromCallData($this->call);
/** @var Participant $prospectParticipant */
$prospectParticipant = $activity
->participants()
->where(function (Builder $query) use ($activity) {
$query
->whereNull('user_id')
->orWhere('user_id', '!=', $activity->getUserId())
;
})
->first()
;
$activity->updateParticipantCrmData($crmObjects, $prospectParticipant);
}
$this->logMessage('Activity updated');
$this->triggerSummaryPushIfReady($activity, $eventDispatcher);
}
private function triggerSummaryPushIfReady(Activity $activity, Dispatcher $eventDispatcher): void
{
if (! $activity->hasTranscriptionId()) {
return;
}
if ($activity->hasProspectActivitySummaryLog()) {
$this->logMessage('Summary already sent to prospect, skipping summary push after CRM matching');
return;
}
$this->logMessage('Triggering summary push after CRM matching');
$eventDispatcher->dispatch(new TranscriptionAiSummaryReadyEvent($activity->getUuid()));
}
private function initialiseCrmService(Activity $activity, ProviderRegistry $providerRegistry): void
{
$this->team = $activity->getUser()->getTeam();
$crmProviderName = $this->team->getCrmConfiguration()->getProviderName();
$crmService = $providerRegistry->get($crmProviderName);
$crmService->setUser($this->team->getOwner());
$this->crmService = $crmService;
$this->logContext['team'] = $this->team->getSlug();
$this->logContext['team_id'] = $this->team->getId();
}
private function logMessage(string $message): void
{
$this->logger->info(sprintf('[MatchCrmData] %s', $message), $this->logContext);
}
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Jobs\Activity\Import;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Events\Dispatcher;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Jiminny\Component\Queue\Constants;
use Jiminny\Component\Utility\Service\ProviderRateLimiter;
use Jiminny\Contracts\Services\Crm\ServiceInterface;
use Jiminny\DTO\ImportCall\Call;
use Jiminny\Component\TranscriptionSummary\Events\TranscriptionAiSummaryReadyEvent;
use Jiminny\Events\Activities\AiAutomation\ActivityProspectAdded;
use Jiminny\Exceptions\SocialAccountTokenInvalidException;
use Jiminny\Models\Activity;
use Jiminny\Models\Participant;
use Jiminny\Models\Team;
use Jiminny\Repositories\ActivityRepository;
use Jiminny\Services\Crm\CrmObjectsResolver;
use Jiminny\Services\Crm\ProspectSearchStrategyFactory;
use Jiminny\Services\Crm\ProviderRegistry;
use Psr\Log\LoggerInterface;
class MatchCrmData implements ShouldQueue
{
use Dispatchable;
use InteractsWithQueue;
use Queueable;
// AWS visibility timeout allows a maximum of 12 hours. This is 1 minute less.
private const int MAX_DELAY = 43140;
// Infrastructure allows max 3 retries (1 initial execution + 3 retries)
public int $tries = 4;
private Call $call;
private int $activityId;
private Team $team;
private ServiceInterface $crmService;
private LoggerInterface $logger;
private array $logContext;
public function __construct(Call $call, int $activityId)
{
$this->call = $call;
$this->activityId = $activityId;
$this->logContext = [
'activity_id' => $activityId,
'call_id' => $call->getCallId(),
'provider' => $call->getProvider(),
];
$this->onQueue(Constants::QUEUE_DIALERS);
}
public function handle(
CrmObjectsResolver $crmObjectsResolver,
ProviderRegistry $providerRegistry,
ProviderRateLimiter $rateLimiter,
ActivityRepository $activityRepository,
LoggerInterface $logger,
Dispatcher $eventDispatcher,
): void {
$this->logger = $logger;
// Activity is already augmented with CRM data, no need to perform the same operation
if ($this->call->isActivityUpdatedWithCrm()) {
$this->logMessage('Skipping activity. Already updated with CRM data');
return;
}
/** @var Activity $activity */
$activity = $activityRepository->findById($this->activityId);
try {
$this->initialiseCrmService($activity, $providerRegistry);
} catch (SocialAccountTokenInvalidException $exception) {
$this->logMessage('Invalid token, retrying');
$this->release(self::MAX_DELAY); // Try again tomorrow
return;
}
$prospectSearchStrategy = ProspectSearchStrategyFactory::match($this->team);
if ($prospectSearchStrategy->ignoreCrmMatchData()) {
// Ignore any associated opportunity
$this->logger->info('[MatchCrmData] Ignoring crm data because of prospect strategy', [
'activity_id' => $this->activityId,
'strategy' => get_class($prospectSearchStrategy),
]);
return;
}
if (! $rateLimiter->canMakeRequest($activity->getCrm())) {
$this->logMessage('Rate limit reached, retrying');
$this->release($rateLimiter->requestAvailableIn($activity->getCrm()) + random_int(1, 60));
return;
}
$this->logMessage('Resolving CRM objects');
$crmObjects = $crmObjectsResolver->resolveFromCall($this->crmService, $this->call);
$rateLimiter->incrementRequestCount($activity->getCrm());
if (empty($crmObjects)) {
$this->logMessage('Could not resolve CRM objects, retrying');
$this->release(3600);
return;
}
[$lead, $account, $opportunity, $contact, $stage] = $crmObjects;
$activity->update([
'lead_id' => $lead->id ?? null,
'contact_id' => $contact->id ?? null,
'account_id' => $account->id ?? null,
'opportunity_id' => $opportunity->id ?? null,
'stage_id' => $stage->id ?? null,
]);
$activity->refresh();
$eventDispatcher->dispatch(new ActivityProspectAdded(
activity: $activity,
eventSource: 'match-crm-data'
));
if ($activity->getProspectName() !== null) {
$activity->setTitleFromCallData($this->call);
/** @var Participant $prospectParticipant */
$prospectParticipant = $activity
->participants()
->where(function (Builder $query) use ($activity) {
$query
->whereNull('user_id')
->orWhere('user_id', '!=', $activity->getUserId())
;
})
->first()
;
$activity->updateParticipantCrmData($crmObjects, $prospectParticipant);
}
$this->logMessage('Activity updated');
$this->triggerSummaryPushIfReady($activity, $eventDispatcher);
}
private function triggerSummaryPushIfReady(Activity $activity, Dispatcher $eventDispatcher): void
{
if (! $activity->hasTranscriptionId()) {
return;
}
if ($activity->hasProspectActivitySummaryLog()) {
$this->logMessage('Summary already sent to prospect, skipping summary push after CRM matching');
return;
}
$this->logMessage('Triggering summary push after CRM matching');
$eventDispatcher->dispatch(new TranscriptionAiSummaryReadyEvent($activity->getUuid()));
}
private function initialiseCrmService(Activity $activity, ProviderRegistry $providerRegistry): void
{
$this->team = $activity->getUser()->getTeam();
$crmProviderName = $this->team->getCrmConfiguration()->getProviderName();
$crmService = $providerRegistry->get($crmProviderName);
$crmService->setUser($this->team->getOwner());
$this->crmService = $crmService;
$this->logContext['team'] = $this->team->getSlug();
$this->logContext['team_id'] = $this->team->getId();
}
private function logMessage(string $message): void
{
$this->logger->info(sprintf('[MatchCrmData] %s', $message), $this->logContext);
}
}...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
11 files, folder partially checked
app 9 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder partially checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder not checked
Middleware 1 file, folder not checked
Services/Crm/Hubspot 4 files, folder not checked
config 1 file, folder not checked
.env.local not checked
app 9 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder partially checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder not checked
Middleware 1 file, folder not checked
Services/Crm/Hubspot 4 files, folder not checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder partially checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
Crm 1 file, folder not checked
Middleware 1 file, folder not checked
Activity/Import 1 file, folder checked
MatchCrmData.php, class checked
MatchCrmData.php, class checked
Crm 1 file, folder not checked
Middleware 1 file, folder not checked
Services/Crm/Hubspot 4 files, folder not checked
config 1 file, folder not checked
.env.local not checked
1 modified
Move non paginator search calls to client->search
Commit Message
Commit Message History
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
2 differences
35f036ac
<?php
declare(strict_types=1);
namespace Jiminny\Jobs\Activity\Import;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Events\Dispatcher;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Jiminny\Component\Queue\Constants;
use Jiminny\Component\Utility\Service\ProviderRateLimiter;
use Jiminny\Contracts\Services\Crm\ServiceInterface;
use Jiminny\DTO\ImportCall\Call;
use Jiminny\Component\TranscriptionSummary\Events\TranscriptionAiSummaryReadyEvent;
use Jiminny\Events\Activities\AiAutomation\ActivityProspectAdded;
use Jiminny\Exceptions\SocialAccountTokenInvalidException;
use Jiminny\Models\Activity;
use Jiminny\Models\Participant;
use Jiminny\Models\Team;
use Jiminny\Repositories\ActivityRepository;
use Jiminny\Services\Crm\CrmObjectsResolver;
use Jiminny\Services\Crm\ProspectSearchStrategyFactory;
use Jiminny\Services\Crm\ProviderRegistry;
use Psr\Log\LoggerInterface;
class MatchCrmData implements ShouldQueue
{
use Dispatchable;
use InteractsWithQueue;
use Queueable;
// AWS visibility timeout allows a maximum of 12 hours. This is 1 minute less.
private const int MAX_DELAY = 43140;
// Infrastructure allows max 3 retries (1 initial execution + 3 retries)
public int $tries = 4;
private Call $call;
private int $activityId;
private Team $team;
private ServiceInterface $crmService;
private LoggerInterface $logger;
private array $logContext;
public function __construct(Call $call, int $activityId)
{
$this->call = $call;
$this->activityId = $activityId;
$this->logContext = [
'activity_id' => $activityId,
'call_id' => $call->getCallId(),
'provider' => $call->getProvider(),
];
$this->onQueue(Constants::QUEUE_DIALERS);
}
public function handle(
CrmObjectsResolver $crmObjectsResolver,
ProviderRegistry $providerRegistry,
ProviderRateLimiter $rateLimiter,
ActivityRepository $activityRepository,
LoggerInterface $logger,
Dispatcher $eventDispatcher,
): void {
$this->logger = $logger;
// Activity is already augmented with CRM data, no need to perform the same operation
if ($this->call->isActivityUpdatedWithCrm()) {
$this->logMessage('Skipping activity. Already updated with CRM data');
return;
}
/** @var Activity $activity */
$activity = $activityRepository->findById($this->activityId);
try {
$this->initialiseCrmService($activity, $providerRegistry);
} catch (SocialAccountTokenInvalidException $exception) {
$this->logMessage('Invalid token, retrying');
$this->release(self::MAX_DELAY); // Try again tomorrow
return;
}
$prospectSearchStrategy = ProspectSearchStrategyFactory::match($this->team);
if ($prospectSearchStrategy->ignoreCrmMatchData()) {
// Ignore any associated opportunity
$this->logger->info('[MatchCrmData] Ignoring crm data because of prospect strategy', [
'activity_id' => $this->activityId,
'strategy' => get_class($prospectSearchStrategy),
]);
return;
}
if (! $rateLimiter->canMakeRequest($activity->getCrm())) {
$this->logMessage('Rate limit reached, retrying');
$this->release($rateLimiter->requestAvailableIn($activity->getCrm()) + random_int(1, 60));
return;
}
$this->logMessage('Resolving CRM objects');
$rateLimiter->incrementRequestCount($activity->getCrm());
$crmObjects = $crmObjectsResolver->resolveFromCall($this->crmService, $this->call);
if (empty($crmObjects)) {
$this->logMessage('Could not resolve CRM objects, retrying');
$this->release(3600);
return;
}
[$lead, $account, $opportunity, $contact, $stage] = $crmObjects;
$activity->update([
'lead_id' => $lead->id ?? null,
'contact_id' => $contact->id ?? null,
'account_id' => $account->id ?? null,
'opportunity_id' => $opportunity->id ?? null,
'stage_id' => $stage->id ?? null,
]);
$activity->refresh();
$eventDispatcher->dispatch(new ActivityProspectAdded(
activity: $activity,
eventSource: 'match-crm-data'
));
if ($activity->getProspectName() !== null) {
$activity->setTitleFromCallData($this->call);
/** @var Participant $prospectParticipant */
$prospectParticipant = $activity
->participants()
->where(function (Builder $query) use ($activity) {
$query
->whereNull('user_id')
->orWhere('user_id', '!=', $activity->getUserId())
;
})
->first()
;
$activity->updateParticipantCrmData($crmObjects, $prospectParticipant);
}
$this->logMessage('Activity updated');
$this->triggerSummaryPushIfReady($activity, $eventDispatcher);
}
private function triggerSummaryPushIfReady(Activity $activity, Dispatcher $eventDispatcher): void
{
if (! $activity->hasTranscriptionId()) {
return;
}
if ($activity->hasProspectActivitySummaryLog()) {
$this->logMessage('Summary already sent to prospect, skipping summary push after CRM matching');
return;
}
$this->logMessage('Triggering summary push after CRM matching');
$eventDispatcher->dispatch(new TranscriptionAiSummaryReadyEvent($activity->getUuid()));
}
private function initialiseCrmService(Activity $activity, ProviderRegistry $providerRegistry): void
{
$this->team = $activity->getUser()->getTeam();
$crmProviderName = $this->team->getCrmConfiguration()->getProviderName();
$crmService = $providerRegistry->get($crmProviderName);
$crmService->setUser($this->team->getOwner());
$this->crmService = $crmService;
$this->logContext['team'] = $this->team->getSlug();
$this->logContext['team_id'] = $this->team->getId();
}
private function logMessage(string $message): void
{
$this->logger->info(sprintf('[MatchCrmData] %s', $message), $this->logContext);
}
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Jobs\Activity\Import;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Events\Dispatcher;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Jiminny\Component\Queue\Constants;
use Jiminny\Component\Utility\Service\ProviderRateLimiter;
use Jiminny\Contracts\Services\Crm\ServiceInterface;
use Jiminny\DTO\ImportCall\Call;
use Jiminny\Component\TranscriptionSummary\Events\TranscriptionAiSummaryReadyEvent;
use Jiminny\Events\Activities\AiAutomation\ActivityProspectAdded;
use Jiminny\Exceptions\SocialAccountTokenInvalidException;
use Jiminny\Models\Activity;
use Jiminny\Models\Participant;
use Jiminny\Models\Team;
use Jiminny\Repositories\ActivityRepository;
use Jiminny\Services\Crm\CrmObjectsResolver;
use Jiminny\Services\Crm\ProspectSearchStrategyFactory;
use Jiminny\Services\Crm\ProviderRegistry;
use Psr\Log\LoggerInterface;
class MatchCrmData implements ShouldQueue
{
use Dispatchable;
use InteractsWithQueue;
use Queueable;
// AWS visibility timeout allows a maximum of 12 hours. This is 1 minute less.
private const int MAX_DELAY = 43140;
// Infrastructure allows max 3 retries (1 initial execution + 3 retries)
public int $tries = 4;
private Call $call;
private int $activityId;
private Team $team;
private ServiceInterface $crmService;
private LoggerInterface $logger;
private array $logContext;
public function __construct(Call $call, int $activityId)
{
$this->call = $call;
$this->activityId = $activityId;
$this->logContext = [
'activity_id' => $activityId,
'call_id' => $call->getCallId(),
'provider' => $call->getProvider(),
];
$this->onQueue(Constants::QUEUE_DIALERS);
}
public function handle(
CrmObjectsResolver $crmObjectsResolver,
ProviderRegistry $providerRegistry,
ProviderRateLimiter $rateLimiter,
ActivityRepository $activityRepository,
LoggerInterface $logger,
Dispatcher $eventDispatcher,
): void {
$this->logger = $logger;
// Activity is already augmented with CRM data, no need to perform the same operation
if ($this->call->isActivityUpdatedWithCrm()) {
$this->logMessage('Skipping activity. Already updated with CRM data');
return;
}
/** @var Activity $activity */
$activity = $activityRepository->findById($this->activityId);
try {
$this->initialiseCrmService($activity, $providerRegistry);
} catch (SocialAccountTokenInvalidException $exception) {
$this->logMessage('Invalid token, retrying');
$this->release(self::MAX_DELAY); // Try again tomorrow
return;
}
$prospectSearchStrategy = ProspectSearchStrategyFactory::match($this->team);
if ($prospectSearchStrategy->ignoreCrmMatchData()) {
// Ignore any associated opportunity
$this->logger->info('[MatchCrmData] Ignoring crm data because of prospect strategy', [
'activity_id' => $this->activityId,
'strategy' => get_class($prospectSearchStrategy),
]);
return;
}
if (! $rateLimiter->canMakeRequest($activity->getCrm())) {
$this->logMessage('Rate limit reached, retrying');
$this->release($rateLimiter->requestAvailableIn($activity->getCrm()) + random_int(1, 60));
return;
}
$this->logMessage('Resolving CRM objects');
$crmObjects = $crmObjectsResolver->resolveFromCall($this->crmService, $this->call);
$rateLimiter->incrementRequestCount($activity->getCrm());
if (empty($crmObjects)) {
$this->logMessage('Could not resolve CRM objects, retrying');
$this->release(3600);
return;
}
[$lead, $account, $opportunity, $contact, $stage] = $crmObjects;
$activity->update([
'lead_id' => $lead->id ?? null,
'contact_id' => $contact->id ?? null,
'account_id' => $account->id ?? null,
'opportunity_id' => $opportunity->id ?? null,
'stage_id' => $stage->id ?? null,
]);
$activity->refresh();
$eventDispatcher->dispatch(new ActivityProspectAdded(
activity: $activity,
eventSource: 'match-crm-data'
));
if ($activity->getProspectName() !== null) {
$activity->setTitleFromCallData($this->call);
/** @var Participant $prospectParticipant */
$prospectParticipant = $activity
->participants()
->where(function (Builder $query) use ($activity) {
$query
->whereNull('user_id')
->orWhere('user_id', '!=', $activity->getUserId())
;
})
->first()
;
$activity->updateParticipantCrmData($crmObjects, $prospectParticipant);
}
$this->logMessage('Activity updated');
$this->triggerSummaryPushIfReady($activity, $eventDispatcher);
}
private function triggerSummaryPushIfReady(Activity $activity, Dispatcher $eventDispatcher): void
{
if (! $activity->hasTranscriptionId()) {
return;
}
if ($activity->hasProspectActivitySummaryLog()) {
$this->logMessage('Summary already sent to prospect, skipping summary push after CRM matching');
return;
}
$this->logMessage('Triggering summary push after CRM matching');
$eventDispatcher->dispatch(new TranscriptionAiSummaryReadyEvent($activity->getUuid()));
}
private function initialiseCrmService(Activity $activity, ProviderRegistry $providerRegistry): void
{
$this->team = $activity->getUser()->getTeam();
$crmProviderName = $this->team->getCrmConfiguration()->getProviderName();
$crmService = $providerRegistry->get($crmProviderName);
$crmService->setUser($this->team->getOwner());
$this->crmService = $crmService;
$this->logContext['team'] = $this->team->getSlug();
$this->logContext['team_id'] = $this->team->getId();
}
private function logMessage(string $message): void
{
$this->logger->info(sprintf('[MatchCrmData] %s', $message), $this->logContext);
}
}
Help
Cancel
Shelve Changes
Shelve Changes...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
12 files, folder partially checked
app 10 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder not checked
Services/Crm/Hubspot 5 files, folder partially checked
Pagination 2 files, folder not checked
Client.php, class not checked
HubspotClientInterface.php, interface not checked
Service.php, class checked
config 1 file, folder not checked...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
12 files, folder partially checked
app 10 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder not checked
Services/Crm/Hubspot 5 files, folder partially checked
Pagination 2 files, folder not checked
Client.php, class not checked
HubspotClientInterface.php, interface not checked
Service.php, class checked
config 1 file, folder not checked
.env.local not checked
app 10 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder not checked
Services/Crm/Hubspot 5 files, folder partially checked
Pagination 2 files, folder not checked
Client.php, class not checked
HubspotClientInterface.php, interface not checked
Service.php, class checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder not checked
Services/Crm/Hubspot 5 files, folder partially checked
Pagination 2 files, folder not checked
Client.php, class not checked
HubspotClientInterface.php, interface not checked
Service.php, class checked
Pagination 2 files, folder not checked
Client.php, class not checked
HubspotClientInterface.php, interface not checked
Service.php, class checked
config 1 file, folder not checked
.env.local not checked
1 modified
Almost ready one call to be tested
Commit Message
Commit Message History
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
12 files, folder partially checked
app 10 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder not checked
Services/Crm/Hubspot 5 files, folder partially checked
Pagination 2 files, folder not checked
Client.php, class not checked
HubspotClientInterface.php, interface not checked
Service.php, class checked
config 1 file, folder not checked
.env.local not checked
app 10 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder not checked
Services/Crm/Hubspot 5 files, folder partially checked
Pagination 2 files, folder not checked
Client.php, class not checked
HubspotClientInterface.php, interface not checked
Service.php, class checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder not checked
Jobs 3 files, folder not checked
Services/Crm/Hubspot 5 files, folder partially checked
Pagination 2 files, folder not checked
Client.php, class not checked
HubspotClientInterface.php, interface not checked
Service.php, class checked
Pagination 2 files, folder not checked
Client.php, class not checked
HubspotClientInterface.php, interface not checked
Service.php, class checked
config 1 file, folder not checked
.env.local not checked
1 modified
Almost ready one call to be tested
Commit Message
Commit Message History
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
12 files, folder partially checked
app 8 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
12 files, folder partially checked
app 8 files, folder partially checked
Console/Commands 1 file, folder not checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
Jobs 2 files, folder checked
Crm 1 file, folder checked
MatchActivityCrmData.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Services/Crm/Hubspot 4 files, folder checked...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
2 modified
JY-20725 add HS rate limit handling on activities rematching
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
2 modified
JY-20725 add HS rate limit handling on activities rematching
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
2 modified
JY-20725 add HS rate limit handling on activities rematching
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
PhostormProiect vVIeWINavicarecodeKeractorWindowmelprTavsco.s°9 JY-20725-handle-HS-search© MatchActivityCrmDataTest.php >RematchActivityOnCrmObjectDetach.php© HubspotPaginationService.phpOlrackAutomatedkeportceneratedevent.ongUserautomateakeporscontroller.ong© PlaybackController.php* [Platform] Refinemen... 49 m left100% 5• Mon 11 May 16:11:40Ok Where is it used, will I break something it is replace LogicException with RuntimeException in RateLimitException?Commit ChanaesChangelist:Changesv V M.Jobs/Crm 1 filev © MatchActivityCrmDataTest.phpV Services/Crm/Hubspot/Pagination 1 file© HubspotPaginationServiceTest.phpAuthorAmend commitSian-off commitocuing No aalaf"correlationid": "954d156d-8a4f-45.°l Pollingl Maximum empty results reached, stopping {"empty.l Pollingl Maximum empty results reached, stopping {"empty.lollingl Service ending {"runtime_seconds":57, "total_cyclesPollingl Saved offset to database on cleanup {"offset":"019€'ollingl Released polling lock {"correlation_ id"."954d156đmmands\ Command::run Memory usage before starting command {Searched RateLimitException in -iminnylapp (php) (44)Inoughttor 2s>Searched throw new RateLimit Excention and pertormed 1 other quervY2, 11n0 AM Giiy usage quota is exhausted. Purchase extra usage to continue using premium models. Quota resets Mayal "2 modifiedCommit MessageJY-20725 a00 HS rate Limit nanduino on actavitles rematchinaCommit checksUodate copvrichiPeformat codeRearrange codeOpuimize imporisv DiftARTING batch process ?"host":"docker_Lamp_1"} 1"correlatiINISHED batch process ""host":"docker_lamp_1""processed":0mmands\Command::run Memory usage for command {"command":mmands Command::run Memory usage before startina commandmmands\Command: :run Memory usage for command {"command" : "CIs Startind sunc <"team":"020115e0-95ce-4010-929c-175757078int not connected for user {"userId":"33e34a7a-1c02-4f04-87Intearation owner is not connected. attemotina team membenNo team members found with active crm connection {"crm_pYour inciuded dally usage quota is ex.. Purchase extra usage to continue using premium models. Quota resets Mav 12. 11:00)Ask anything (&AL)<> CodeS AdaptiveI@¢→Side-by-side viewerDo notignoreHighlight woras@ 44d5678c tests/Unit/Jobs/Crm/MatchActMiyuimDatalest.onoTroncontigoracson. noct,remoteSearch: false,4 omerences• current versionfromConfiguration: null,nemoteSeanch• false.27 differencescurrent version$this->assertSame(3, Sjob->tries):$this->assertSame(300, Sjob->timeoutO):$this->assertSame(360, Sjob->uniqueForO):$this->assertSame([30, 90, 180], Sjob->backof178 MSthis->assertSame(3, Sjob->maxExceptions):Sthis-saccentSame (300 Cinh->timenuto)•Sjob->uniqueFor());Sthis->assertSame([30, 90, 180], Sjob->backof- IEIUUT METOS->with('[Hubspot] Pagination completed', Sthis->anythingO):\Tests|Unit|Services|Crm\Hubspot\Pagination > HubspotPaginationServiceTest > testGetPaginatedDataGeneratorWithEmptyResults() ~Stype = 'contacts':$total = 0:SlastRecordId = null:‹> >© ImportOpportunityBa© MatchActivitiesToNe© Hubspot/service.ongС маchAcuvitycrmDa© SaveActivityTest.phgT DeleteCrmEntityTrait.php© Veri© SaveTranscriptionTeseluoLavoutlest.ongC SubscribeForEvents.RateLimitException.pho(C) HandleHubspotRateLimit.php© Clien© SyncActivity Test.phf © CrmObiectsResolver.php(C) ProviderRateLimiter.php(C) Paqinaticc) SyncHubspotObiects<?phpc) SvncLeadstest.phpc) Svncobiectstest.ohdeclare(strict tyoessio%c) SvncOpportunitiesJoC SvncOpportunitvTesnamespace Tests Unit obs Crm.c) SuncProflleLeadstresC SvncProfileMetadata› use ...c) SvncProfile@pportunC SvncTeamFields Jobiclass MatchActivityCrmDataTest extends TestCasec) SvncTeamMetadatan( Teaminitia|Svnc lobTc UindateProfileRelatec20 usagesLog Xprivate ActivityRepository|Mock0bject SactivitCancola yLocal ChangesChanaes 5 files= env.local ano8 44d5678c tests/Lc) HubsootPadinationServiceTest.oho tests/Unit/Services/Crm/Hubsoot/Padinat© JiminnyDebugCommand.php app/Console/Commandsphp logging.php configSthis-© MatchActivityCrmDataTest.php tests/Unit/Jobs/CrmUnversioned Files 9 files.env.nikilocal appE .env.other apr© CanAccessAiReportsTest.php tests/Unit/Policies© CreateMockAskJiminnyReportResultCommand.php app/Console/Commands/Re& favicon.ico publicE ids.txt appT raw sal_querv.sal app© SimulateWebhooksCommand.php app/Console/Commands/Crm/HubspotM+ WEBHOOK_FILTERING_IMPLEMENTATION.md app=custom.log=laravel.log X 4 SF (jiminny@localhost]4 HS_local jiminny@localhost]# console [PRol)# console [eu)A console [STAGING]429x 5 CcW .*231242JY:Hubspot Rate Limit Re+0 ..public function testUniqueldO: voidpublic function testUniqueldo: voidCancelSthis->clientMock->expects(Sthis->onceo)->method ('se->w1LLReturn(l'results' =>=>0%sthis-sassertznotycresults):Sthis-›assertEquals(0, $total);Sthis->assertNul1($lastRecordId):Sthis-> loogerlock->expects(Sthis->once@)->method('info')orivate function createHubspotResoonse(arrav Sdata): HubsootResoonsereturn new HubspotResponse(new Response(200, [], json_encode($data)));Sthis->assertEmotv(Sresults):Sthis-sassentsqualls(l StotaibsSthis-›assertNull($lastRecordId);fo 4 spaces...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
20 files, folder partially checked
app 18 files, folder partially checked
Component/Datadog 1 file, folder not checked
Console/Commands 1 file, folder checked
JiminnyDebugCommand.php, class checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
Jobs 8 files, folder checked
Activity 3 files, folder checked
Import 2 files, folder checked
HydrateCrmDataByExternalCallIdJob.php, class checked
MatchCrmData.php, class checked
ConferenceCrmMatcherJob.php, class checked
Crm 4 files, folder checked
Hubspot 1 file, folder checked
ImportBatchJobTrait.php checked
MatchActivityCrmData.php, class checked
SyncHubspotObjects.php, class checked
SyncOpportunitiesJob.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Services 7 files, folder partially checked
Crm/Hubspot 5 files, folder checked
Pagination 1 file, folder checked
HubspotPaginationService.php, class checked
ServiceTraits 1 file, folder checked
OpportunitySyncTrait.php checked
Client.php, class checked
HubspotClientInterface.php, interface checked
Service.php, class checked
Kiosk/AutomatedReports 1 file, folder not checked
PlaybackService.php, class checked
config 1 file, folder checked
logging.php checked
.env.local not checked
app 18 files, folder partially checked
Component/Datadog 1 file, folder not checked
Console/Commands 1 file, folder checked
JiminnyDebugCommand.php, class checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
Jobs 8 files, folder checked
Activity 3 files, folder checked
Import 2 files, folder checked
HydrateCrmDataByExternalCallIdJob.php, class checked
MatchCrmData.php, class checked
ConferenceCrmMatcherJob.php, class checked
Crm 4 files, folder checked
Hubspot 1 file, folder checked
ImportBatchJobTrait.php checked
MatchActivityCrmData.php, class checked
SyncHubspotObjects.php, class checked
SyncOpportunitiesJob.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Services 7 files, folder partially checked
Crm/Hubspot 5 files, folder checked
Pagination 1 file, folder checked
HubspotPaginationService.php, class checked
ServiceTraits 1 file, folder checked
OpportunitySyncTrait.php checked
Client.php, class checked
HubspotClientInterface.php, interface checked
Service.php, class checked
Kiosk/AutomatedReports 1 file, folder not checked
PlaybackService.php, class checked
Component/Datadog 1 file, folder not checked
Console/Commands 1 file, folder checked
JiminnyDebugCommand.php, class checked
JiminnyDebugCommand.php, class checked
Exceptions 1 file, folder checked
RateLimitException.php, exception class checked
RateLimitException.php, exception class checked
Jobs 8 files, folder checked
Activity 3 files, folder checked
Import 2 files, folder checked
HydrateCrmDataByExternalCallIdJob.php, class checked
MatchCrmData.php, class checked
ConferenceCrmMatcherJob.php, class checked
Crm 4 files, folder checked
Hubspot 1 file, folder checked
ImportBatchJobTrait.php checked
MatchActivityCrmData.php, class checked
SyncHubspotObjects.php, class checked
SyncOpportunitiesJob.php, class checked
Middleware 1 file, folder checked
HandleHubspotRateLimit.php, class checked
Activity 3 files, folder checked
Import 2 files, folder checked
HydrateCrmDataByExternalCallIdJob.php, class checked
MatchCrmData.php, class checked
ConferenceCrmMatcherJob.php, class checked
Import 2 files, folder checked
HydrateCrmDataByExternalCallIdJob.php, class checked
MatchCrmData.php, class checked
HydrateCrmDataByExternalCallIdJob.php, class checked
MatchCrmData.php, class checked...
|
PhpStorm
|
Shelve Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
3 added 6 modified
JY-20725 add HS rate limit handling on Actvities rematching
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
3 added 6 modified
JY-20725 add HS rate limit handling on Actvities rematching
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
3 modified
JY-20818 move ask jiminny reports event
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
1 difference
12295204
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string ASK_JIMINNY_REPORTS = 'jiminny.ask_jiminny_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Help
Cancel
Commit
Commit
Commit Changes...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
3 modified
JY-20818 move ask jiminny reports event
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
1 difference
12295204
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string ASK_JIMINNY_REPORTS = 'jiminny.ask_jiminny_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Help
Cancel
Commit
Commit
Commit Changes...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
3 modified
JY-20818 move ask jiminny reports to its own datadog metric
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
1 difference
12295204
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string ASK_JIMINNY_REPORTS = 'jiminny.ask_jiminny_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Help
Cancel
Commit
Commit
Commit Changes...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
3 modified
JY-20818 move ask jiminny reports to its own datadog metric
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
1 difference
12295204
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string ASK_JIMINNY_REPORTS = 'jiminny.ask_jiminny_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Help
Cancel
Commit
Commit
Commit Changes...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
3 modified
hubspot rate limit temp checkout
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
1 difference
12295204
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string ASK_JIMINNY_REPORTS = 'jiminny.ask_jiminny_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Help
Cancel
Commit
Commit
Commit Changes...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
3 modified
hubspot rate limit temp checkout
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
1 difference
12295204
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Current version
<?php
declare(strict_types=1);
namespace Jiminny\Component\Datadog;
final class Constants
{
public const float FULL_SAMPLE_RATE = 1.0;
public const string ELASTICSEARCH_REFRESH_WAITING_TIME = 'jiminny.elasticsearch.refresh.waiting_time';
public const string ELASTICSEARCH_INSTANT_INSERT = 'jiminny.elasticsearch.instant-write';
public const string ELASTICSEARCH_ASYNC_INSERT = 'jiminny.elasticsearch.async-write';
public const string ELASTICSEARCH_ASYNC_DELETE = 'jiminny.elasticsearch.async-delete';
public const string TRACK_IMPORTED = 'jiminny.track.imported';
public const string TRACK_NO_AUDIO = 'jiminny.track.no_audio';
public const string AUTOSCORE_CALCULATED = 'jiminny.autoscore.calculated';
public const string SCORECARD_CREATED = 'jiminny.scorecard.created';
public const string ACTIVITY_TRANSCRIPTION = 'jiminny.activity.transcription';
public const string ACTIVITIES_INSTANT_PROCESSED_COUNT = 'jiminny.activities.instant.processed.count';
public const string ACTIVITIES_PROCESSED_COUNT = 'jiminny.activities.processed.count';
public const string ACTIVITIES_NOT_PROCESSED_COUNT = 'jiminny.activities.not_processed.count';
public const string MEETINGS_CAPTURE_RATE = 'jiminny.conference';
public const string MEETINGS_CAPTURE_RATE_MEETING_STARTED = 'jiminny.conference.started';
public const string MEETINGS_CAPTURE_RATE_MEETING_ENDED = 'jiminny.conference.ended';
public const string MEETINGS_CAPTURE_RATE_FAILURE = 'jiminny.conference.failure';
public const string MEETINGS_CAPTURE_TIMING_BOT_DELAY = 'jiminny.conference.bot_delay';
public const string MEETINGS_CAPTURE_RATE_CAPTURE_RESULT = 'jiminny.conference.capture_result';
public const string CUSTOMER_API = 'jiminny.customer_api';
public const string ACTIVITY_LANGUAGE_DETECTION_SUCCESS = 'jiminny.activity.language_detection.success';
public const string ACTIVITY_LANGUAGE_DETECTION_FAIL = 'jiminny.activity.language_detection.fail';
public const string ASK_JIMINNY_DEAL_TEAM_REQUEST = 'jiminny.ask_jiminny_deals.team_write_requests';
public const string ASK_JIMINNY_DEAL_TEAM_READ_REQUEST = 'jiminny.ask_jiminny_deals.team_read_requests';
public const string CRM_AUTO_SYNC = 'jiminny.crm.auto-sync';
public const string ACTIVITIES_DIALERS_STATS = 'jiminny.activities.dialers.stats';
public const string ACTIVITIES_DIALERS_REASON_STATS = 'jiminny.activities.dialers.reason.stats';
public const string ACTIVITIES_DIALERS_TRACK_IMPORTED = 'jiminny.activities.dialers.track.imported';
public const string ACTIVITIES_DIALERS_TRACK_DURATION = 'jiminny.activities.dialers.track.duration';
public const string AI_AUTOMATION_CRM_WRITE_EXECUTED = 'jiminny.ai_automation.crm_update_executed';
public const string AUTOMATED_REPORTS = 'jiminny.automated_reports.usage';
public const string ASK_JIMINNY_REPORTS = 'jiminny.ask_jiminny_reports.usage';
public const string HUBSPOT_WEBHOOK_SYNC = 'jiminny.crm.hubspot_webhook_sync';
public const string AI_ACTIVITY_TYPE = 'jiminny.ai_activity_type';
public const string AI_CALL_SCORING = 'jiminny.ai_call_scoring';
public const string WEBHOOK_DELIVERY_SUCCESS = 'jiminny.webhook.delivery.success';
public const string WEBHOOK_DELIVERY_FAILED = 'jiminny.webhook.delivery.failed';
public const string ACTIVITY_PROCESSING_STEP_TIME = 'jiminny.activity.processing.step.time';
}
Help
Cancel
Commit
Commit
Commit Changes...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
4 files, folder partially checked
app 2 files, folder checked
Component/Datadog 1 file, folder checked
Constants.php, final class checked
Services/Kiosk/AutomatedReports 1 file, folder checked
AutomatedReportsCallbackService.php, class checked
tests/Unit/Services/Kiosk/AutomatedReports 1 file, folder checked
AutomatedReportsCallbackServiceTest.php, class checked
.env.local not checked
app 2 files, folder checked
Component/Datadog 1 file, folder checked
Constants.php, final class checked
Services/Kiosk/AutomatedReports 1 file, folder checked
AutomatedReportsCallbackService.php, class checked
Component/Datadog 1 file, folder checked
Constants.php, final class checked
Constants.php, final class checked
Services/Kiosk/AutomatedReports 1 file, folder checked
AutomatedReportsCallbackService.php, class checked
AutomatedReportsCallbackService.php, class checked
tests/Unit/Services/Kiosk/AutomatedReports 1 file, folder checked
AutomatedReportsCallbackServiceTest.php, class checked
AutomatedReportsCallbackServiceTest.php, class checked
.env.local not checked
Unversioned Files 9 files not checked
3 modified
hubspot rate limit temp checkout
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
4 files, folder partially checked
app/Console/Commands 1 file, folder not checked
config 1 file, folder not checked
tests/Unit/Services/Crm/Hubspot 1 file, folder checked
ClientTest.php, class checked
.env.local not checked
app/Console/Commands 1 file, folder not checked
config 1 file, folder not checked
tests/Unit/Services/Crm/Hubspot 1 file, folder checked
ClientTest.php, class checked
ClientTest.php, class checked
.env.local not checked...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
4 files, folder partially checked
app/Console/Commands 1 file, folder not checked
config 1 file, folder not checked
tests/Unit/Services/Crm/Hubspot 1 file, folder checked
ClientTest.php, class checked
.env.local not checked
app/Console/Commands 1 file, folder not checked
config 1 file, folder not checked
tests/Unit/Services/Crm/Hubspot 1 file, folder checked
ClientTest.php, class checked
ClientTest.php, class checked
.env.local not checked
Unversioned Files 9 files not checked
1 modified
JY-20725 add tests
Commit Message
Commit Message History
Git
Author:
Author:...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
4 files, folder partially checked
app/Console/Commands 1 file, folder not checked
config 1 file, folder not checked
tests/Unit/Services/Crm/Hubspot 1 file, folder checked
ClientTest.php, class checked
.env.local not checked
app/Console/Commands 1 file, folder not checked
config 1 file, folder not checked
tests/Unit/Services/Crm/Hubspot 1 file, folder checked
ClientTest.php, class checked
ClientTest.php, class checked
.env.local not checked
Unversioned Files 9 files not checked
1 modified
JY-20725 add tests
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
6 differences
cbed2c9a
<?php
declare(strict_types=1);
namespace Tests\Unit\Services\Crm\Hubspot;
use GuzzleHttp\Psr7\Response;
use HubSpot\Client\Crm\Associations\Api\BatchApi;
use HubSpot\Client\Crm\Associations\Model\BatchInputPublicObjectId;
use HubSpot\Client\Crm\Associations\Model\BatchResponsePublicAssociationMulti;
use HubSpot\Client\Crm\Associations\Model\PublicObjectId;
use HubSpot\Client\Crm\Deals\Api\BasicApi as DealsBasicApi;
use HubSpot\Client\Crm\Deals\Model\SimplePublicObjectWithAssociations as DealWithAssociations;
use HubSpot\Client\Crm\Pipelines\Api\PipelinesApi;
use HubSpot\Client\Crm\Pipelines\Model\CollectionResponsePipeline;
use HubSpot\Client\Crm\Pipelines\Model\Error;
use HubSpot\Client\Crm\Pipelines\Model\Pipeline;
use HubSpot\Client\Crm\Pipelines\Model\PipelineStage;
use HubSpot\Client\Crm\Properties\Api\CoreApi;
use HubSpot\Client\Crm\Properties\Model\Property;
use HubSpot\Discovery as HubSpotDiscovery;
use HubSpot\Discovery\Crm\Deals\Discovery as DealsDiscovery;
use Jiminny\Models\Crm\Configuration;
use Jiminny\Models\Crm\Field;
use Jiminny\Models\SocialAccount;
use Jiminny\Services\Crm\Hubspot\Client;
use Jiminny\Services\Crm\Hubspot\HubspotTokenManager;
use Jiminny\Services\Crm\Hubspot\Pagination\HubspotPaginationService;
use Jiminny\Services\SocialAccountService;
use League\OAuth2\Client\Token\AccessToken;
use PHPUnit\Framework\MockObject\MockObject;
use PHPUnit\Framework\TestCase;
use Psr\Log\NullLogger;
use SevenShores\Hubspot\Endpoints\Engagements;
use SevenShores\Hubspot\Factory;
use SevenShores\Hubspot\Http\Client as HubspotClient;
use SevenShores\Hubspot\Http\Response as HubspotResponse;
/**
* @runTestsInSeparateProcesses
*
* @preserveGlobalState disabled
*/
class ClientTest extends TestCase
{
private const string RESPONSE_TYPE_STAGE_FIELD = 'stage';
private const string RESPONSE_TYPE_PIPELINE_FIELD = 'pipeline';
private const string RESPONSE_TYPE_REGULAR_FIELD = 'regular';
/**
* @var Client&MockObject
*/
private Client $client;
private Configuration $config;
/**
* @var SocialAccountService&MockObject
*/
private SocialAccountService $socialAccountServiceMock;
/**
* @var HubspotPaginationService&MockObject
*/
private HubspotPaginationService $paginationServiceMock;
/**
* @var HubspotTokenManager&MockObject
*/
private HubspotTokenManager $tokenManagerMock;
/**
* @var CoreApi&MockObject
*/
private CoreApi $coreApiMock;
/**
* @var PipelinesApi&MockObject
*/
private PipelinesApi $pipelinesApiMock;
/**
* @var BatchApi&MockObject
*/
private BatchApi $associationsBatchApiMock;
/**
* @var DealsBasicApi&MockObject
*/
private DealsBasicApi $dealsBasicApiMock;
/**
* @var Engagements&MockObject
*/
private $engagementsMock;
/**
* @var HubspotClient&MockObject
*/
private HubspotClient $hubspotClientMock;
protected function setUp(): void
{
// Create mocks for dependencies
$this->socialAccountServiceMock = $this->createMock(SocialAccountService::class);
$this->paginationServiceMock = $this->createMock(HubspotPaginationService::class);
$this->tokenManagerMock = $this->createMock(HubspotTokenManager::class);
// Create a real Client instance with mocked dependencies
// Create a partial mock only for the methods we need to mock
$client = $this->createPartialMock(Client::class, ['getInstance', 'getNewInstance', 'makeRequest']);
$client->setLogger(new NullLogger());
// Inject the real dependencies using reflection
$reflection = new \ReflectionClass(Client::class);
$accountServiceProperty = $reflection->getProperty('accountService');
$accountServiceProperty->setAccessible(true);
$accountServiceProperty->setValue($client, $this->socialAccountServiceMock);
$paginationServiceProperty = $reflection->getProperty('paginationService');
$paginationServiceProperty->setAccessible(true);
$paginationServiceProperty->setValue($client, $this->paginationServiceMock);
$tokenManagerProperty = $reflection->getProperty('tokenManager');
$tokenManagerProperty->setAccessible(true);
$tokenManagerProperty->setValue($client, $this->tokenManagerMock);
$factoryMock = $this->createMock(Factory::class);
$hubspotClientMock = $this->createMock(HubspotClient::class);
$engagementsMock = $this->createMock(\SevenShores\Hubspot\Endpoints\Engagements::class);
$factoryMock->method('getClient')->willReturn($hubspotClientMock);
$factoryMock->method('__call')->with('engagements')->willReturn($engagementsMock);
$client->method('getInstance')->willReturn($factoryMock);
$discoveryMock = $this->createMock(HubSpotDiscovery\Discovery::class);
$crmMock = $this->createMock(HubSpotDiscovery\Crm\Discovery::class);
$associationsMock = $this->createMock(HubSpotDiscovery\Crm\Associations\Discovery::class);
$propertiesMock = $this->createMock(HubSpotDiscovery\Crm\Properties\Discovery::class);
$pipelinesMock = $this->createMock(HubSpotDiscovery\Crm\Pipelines\Discovery::class);
$coreApiMock = $this->createMock(CoreApi::class);
$pipelinesApiMock = $this->createMock(PipelinesApi::class);
$associationsBatchApiMock = $this->createMock(BatchApi::class);
$dealsBasicApiMock = $this->createMock(DealsBasicApi::class);
$propertiesMock->method('__call')->with('coreApi')->willReturn($coreApiMock);
$pipelinesMock->method('__call')->with('pipelinesApi')->willReturn($pipelinesApiMock);
$associationsMock->method('__call')->with('batchApi')->willReturn($associationsBatchApiMock);
$dealsDiscoveryMock = $this->createMock(DealsDiscovery::class);
$dealsDiscoveryMock->method('__call')->with('basicApi')->willReturn($dealsBasicApiMock);
$returnMap = ['properties' => $propertiesMock, 'pipelines' => $pipelinesMock, 'associations' => $associationsMock, 'deals' => $dealsDiscoveryMock];
$crmMock->method('__call')
->willReturnCallback(static fn (string $name) => $returnMap[$name])
;
$discoveryMock->method('__call')->with('crm')->willReturn($crmMock);
$client->method('getNewInstance')->willReturn($discoveryMock);
$this->client = $client;
$this->config = $this->createMock(Configuration::class);
$this->client->setConfiguration($this->config);
$this->coreApiMock = $coreApiMock;
$this->pipelinesApiMock = $pipelinesApiMock;
$this->associationsBatchApiMock = $associationsBatchApiMock;
$this->dealsBasicApiMock = $dealsBasicApiMock;
$this->engagementsMock = $engagementsMock;
$this->hubspotClientMock = $hubspotClientMock;
}
public function testGetMinimumApiVersion(): void
{
$this->assertIsString($this->client->getMinimumApiVersion());
}
public function testGetInstance(): void
{
$socialAccountService = $this->createMock(SocialAccountService::class);
$paginationService = $this->createMock(HubspotPaginationService::class);
$tokenManager = $this->createMock(HubspotTokenManager::class);
$client = new Client($socialAccountService, $paginationService, $tokenManager);
$client->setBaseUrl('[URL_WITH_CREDENTIALS] The class CollectionResponsePipeline will be deprecated in the next Hubspot version
*/
$this->pipelinesApiMock
->method('getAll')
->with('deals')
->willReturn(new CollectionResponsePipeline([
'results' => [$this->generatePipeline()],
]))
;
$this->assertEquals(
[
['id' => 'foo', 'label' => 'bar'],
['id' => 'baz', 'label' => 'qux'],
],
$this->client->fetchOpportunityPipelineStages()
);
}
public function testFetchOpportunityPipelineStagesErrorResponse(): void
{
$this->pipelinesApiMock
->method('getAll')
->with('deals')
->willReturn(new Error(['message' => 'test error']))
;
$this->assertEmpty($this->client->fetchOpportunityPipelineStages());
}
#[\PHPUnit\Framework\Attributes\DataProvider('meetingOutcomeFieldProvider')]
public function testFetchMeetingOutcomeFieldOptions(string $fieldId, string $expectedEndpoint): void
{
$field = new Field(['crm_provider_id' => $fieldId]);
$this->hubspotClientMock
->expects($this->once())
->method('request')
->with('GET', $expectedEndpoint)
->willReturn($this->generateHubSpotResponse(
[
'options' => [
['value' => 'option_1', 'label' => 'Option 1', 'displayOrder' => 0],
['value' => 'option_2', 'label' => 'Option 2', 'displayOrder' => 1],
['value' => 'option_3', 'label' => 'Option 3', 'displayOrder' => 2],
],
]
))
;
$this->assertEquals(
[
['id' => 'option_1', 'value' => 'option_1', 'label' => 'Option 1', 'display_order' => 0],
['id' => 'option_2', 'value' => 'option_2', 'label' => 'Option 2', 'display_order' => 1],
['id' => 'option_3', 'value' => 'option_3', 'label' => 'Option 3', 'display_order' => 2],
],
$this->client->fetchMeetingOutcomeFieldOptions($field)
);
}
public static function meetingOutcomeFieldProvider(): array
{
return [
'meeting outcome field' => [
'meetingOutcome',
'[URL_WITH_CREDENTIALS] The class CollectionResponsePipeline will be deprecated in the next Hubspot version
*/
$pipelineStagesResponse = new CollectionResponsePipeline([
'results' => [$this->generatePipeline()],
]);
$this->pipelinesApiMock
->method('getAll')
->willReturn($pipelineStagesResponse);
}
if ($type === self::RESPONSE_TYPE_PIPELINE_FIELD) {
$field->method('isStageField')->willReturn(false);
$field->method('isPipelineField')->willReturn(true);
$pipelineResponse = $this->generateHubSpotResponse([
'results' => [
['id' => '123', 'label' => 'Sales'],
['id' => 'default', 'label' => 'CS'],
],
]);
$this->client
->method('makeRequest')
->with('/crm/v3/pipelines/deals')
->willReturn($pipelineResponse);
}
$this->assertEquals(
$responses[$type],
$this->client->fetchOpportunityFieldOptions($field)
);
}
public static function opportunityFieldOptionsProvider(): array
{
return [
'stage field' => [
'field' => new Field(['crm_provider_id' => 'dealstage']),
'type' => self::RESPONSE_TYPE_STAGE_FIELD,
],
'pipeline field' => [
'field' => new Field(['crm_provider_id' => 'pipeline']),
'type' => self::RESPONSE_TYPE_PIPELINE_FIELD,
],
'regular field' => [
'field' => new Field(['crm_provider_id' => 'some_property']),
'type' => self::RESPONSE_TYPE_REGULAR_FIELD,
],
];
}
private function generateHubSpotResponse(array $data): HubspotResponse
{
return new HubspotResponse(new Response(200, [], json_encode($data)));
}
private function generateProperty(): Property
{
return new Property([
'name' => 'some_property',
'options' => [
[
'label' => 'label_1',
'value' => 'value_1',
],
[
'label' => 'label_2',
'value' => 'value_2',
],
],
]);
}
private function generatePipeline(): Pipeline
{
return new Pipeline(['stages' => [
new PipelineStage(['id' => 'foo', 'label' => 'bar']),
new PipelineStage(['id' => 'baz', 'label' => 'qux']),
]]);
}
public function testFetchOpportunityPipelines(): void
{
$this->client
->method('makeRequest')
->with('/crm/v3/pipelines/deals')
->willReturn($this->generateHubSpotResponse([
'results' => [
['id' => 'id_1', 'label' => 'Option 1', 'displayOrder' => 0],
['id' => 'id_2', 'label' => 'Option 2', 'displayOrder' => 1],
['id' => 'id_3', 'label' => 'Option 3', 'displayOrder' => 2],
],
]));
$this->assertEquals(
[
['id' => 'id_1', 'label' => 'Option 1'],
['id' => 'id_2', 'label' => 'Option 2'],
['id' => 'id_3', 'label' => 'Option 3'],
],
$this->client->fetchOpportunityPipelines()
);
}
public function testGetPaginatedData(): void
{
$expectedResults = [
['id' => 'id_1', 'properties' => []],
['id' => 'id_2', 'properties' => []],
['id' => 'id_3', 'properties' => []],
];
// Mock the pagination service to return a generator and modify reference parameters
$this->paginationServiceMock
->expects($this->once())
->method('getPaginatedDataGenerator')
->with(
$this->client,
['payload_key' => 'payload_value'],
'foobar',
0,
$this->anything(),
$this->anything()
)
->willReturnCallback(function ($client, $payload, $type, $offset, &$total, &$lastRecordId) use ($expectedResults) {
$total = 3;
$lastRecordId = 'id_3';
foreach ($expectedResults as $result) {
yield $result;
}
});
$this->assertEquals(
[
'results' => $expectedResults,
'total' => 3,
'last_record' => 'id_3',
],
$this->client->getPaginatedData(['payload_key' => 'payload_value'], 'foobar')
);
}
public function testGetAssociationsData(): void
{
$ids = ['1', '2', '3'];
$fromObject = 'deals';
$toObject = 'contacts';
$responseResults = [];
foreach ($ids as $id) {
$from = new PublicObjectId();
$from->setId($id);
$to1 = new PublicObjectId();
$to1->setId('contact_' . $id . '_1');
$to2 = new PublicObjectId();
$to2->setId('contact_' . $id . '_2');
$result = new \HubSpot\Client\Crm\Associations\Model\PublicAssociationMulti();
$result->setFrom($from);
$result->setTo([$to1, $to2]);
$responseResults[] = $result;
}
$batchResponse = new BatchResponsePublicAssociationMulti();
$batchResponse->setResults($responseResults);
$this->associationsBatchApiMock->expects($this->once())
->method('read')
->with(
$this->equalTo($fromObject),
$this->equalTo($toObject),
$this->callback(function (BatchInputPublicObjectId $batchInput) use ($ids) {
$inputIds = array_map(
fn ($input) => $input->getId(),
$batchInput->getInputs()
);
return $inputIds === $ids;
})
)
->willReturn($batchResponse);
$result = $this->client->getAssociationsData($ids, $fromObject, $toObject);
$expectedResult = [
'1' => ['contact_1_1', 'contact_1_2'],
'2' => ['contact_2_1', 'contact_2_2'],
'3' => ['contact_3_1', 'contact_3_2'],
];
$this->assertEquals($expectedResult, $result);
}
public function testGetAssociationsDataHandlesException(): void
{
$ids = ['1', '2', '3'];
$fromObject = 'deals';
$toObject = 'contacts';
$exception = new \Exception('API Error');
$this->associationsBatchApiMock->expects($this->once())
->method('read')
->with(
$this->equalTo($fromObject),
$this->equalTo($toObject),
$this->callback(function ($batchInput) use ($ids) {
return $batchInput instanceof \HubSpot\Client\Crm\Associations\Model\BatchInputPublicObjectId
&& count($batchInput->getInputs()) === count($ids);
})
)
->willThrowException($exception);
$loggerMock = $this->createMock(\Psr\Log\LoggerInterface::class);
$loggerMock->expects($this->once())
->method('error')
->with(
'[Hubspot] Failed to fetch associations',
[
'from_object' => $fromObject,
'to_object' => $toObject,
'reason' => 'API Error',
]
);
$this->client->setLogger($loggerMock);
$result = $this->client->getAssociationsData($ids, $fromObject, $toObject);
$this->assertEmpty($result);
$this->assertIsArray($result);
}
public function testGetAssociationsDataWithLargeDataSet(): void
{
$ids = array_map(fn ($i) => (string) $i, range(1, 2500)); // More than 1000 items
$fromObject = 'deals';
$toObject = 'contacts';
$firstBatchResponse = new BatchResponsePublicAssociationMulti();
$firstBatchResults = array_map(function ($id) {
$from = new PublicObjectId();
$from->setId($id);
$to = new PublicObjectId();
$to->setId('contact_' . $id);
$result = new \HubSpot\Client\Crm\Associations\Model\PublicAssociationMulti();
$result->setFrom($from);
$result->setTo([$to]);
return $result;
}, array_slice($ids, 0, Client::ASSOCIATIONS_BATCH_SIZE_LIMIT));
$firstBatchResponse->setResults($firstBatchResults);
$secondBatchResponse = new BatchResponsePublicAssociationMulti();
$secondBatchResults = array_map(function ($id) {
$from = new PublicObjectId();
$from->setId($id);
$to = new PublicObjectId();
$to->setId('contact_' . $id);
$result = new \HubSpot\Client\Crm\Associations\Model\PublicAssociationMulti();
$result->setFrom($from);
$result->setTo([$to]);
return $result;
}, array_slice($ids, Client::ASSOCIATIONS_BATCH_SIZE_LIMIT));
$secondBatchResponse->setResults($secondBatchResults);
$this->associationsBatchApiMock->expects($this->exactly(3))
->method('read')
->willReturnOnConsecutiveCalls($firstBatchResponse, $secondBatchResponse);
$result = $this->client->getAssociationsData($ids, $fromObject, $toObject);
$this->assertCount(2500, $result);
$this->assertArrayHasKey('1', $result);
$this->assertArrayHasKey('2500', $result);
$this->assertEquals(['contact_1'], $result['1']);
$this->assertEquals(['contact_2500'], $result['2500']);
}
public function testGetContactByEmailSuccess(): void
{
$email = '[EMAIL]';
$fields = ['firstname', 'lastname', 'email'];
$contactMock = $this->createMock(\HubSpot\Client\Crm\Contacts\Model\SimplePublicObjectWithAssociations::class);
$contactMock->method('getId')->willReturn('12345');
$contactMock->method('getProperties')->willReturn([
'firstname' => 'John',
'lastname' => 'Doe',
'email' => '[EMAIL]',
]);
$contactsApiMock = $this->createMock(\HubSpot\Client\Crm\Contacts\Api\BasicApi::class);
$contactsApiMock->expects($this->once())
->method('getById')
->with($email, 'firstname,lastname,email', null, false, 'email')
->willReturn($contactMock);
$contactsDiscoveryMock = $this->createMock(\HubSpot\Discovery\Crm\Contacts\Discovery::class);
$contactsDiscoveryMock->method('__call')->with('basicApi')->willReturn($contactsApiMock);
$crmMock = $this->createMock(\HubSpot\Discovery\Crm\Discovery::class);
$crmMock->method('__call')->willReturnCallback(function ($name) use ($contactsDiscoveryMock) {
if ($name === 'contacts') {
return $contactsDiscoveryMock;
}
return $this->createMock(\HubSpot\Discovery\Crm\Properties\Discovery::class);
});
$discoveryMock = $this->createMock(\HubSpot\Discovery\Discovery::class);
$discoveryMock->method('__call')->with('crm')->willReturn($crmMock);
$client = $this->createPartialMock(Client::class, ['getNewInstance']);
$client->method('getNewInstance')->willReturn($discoveryMock);
$client->setLogger(new NullLogger());
$result = $client->getContactByEmail($email, $fields);
$this->assertEquals([
'id' => '12345',
'properties' => [
'firstname' => 'John',
'lastname' => 'Doe',
'email' => '[EMAIL]',
],
], $result);
}
public function testGetContactByEmailWithEmptyFields(): void
{
$email = '[EMAIL]';
$fields = [];
$contactMock = $this->createMock(\HubSpot\Client\Crm\Contacts\Model\SimplePublicObjectWithAssociations::class);
$contactMock->method('getId')->willReturn('12345');
$contactMock->method('getProperties')->willReturn(['email' => '[EMAIL]']);
$contactsApiMock = $this->createMock(\HubSpot\Client\Crm\Contacts\Api\BasicApi::class);
$contactsApiMock->expects($this->once())
->method('getById')
->with($email, '', null, false, 'email')
->willReturn($contactMock);
$contactsDiscoveryMock = $this->createMock(\HubSpot\Discovery\Crm\Contacts\Discovery::class);
$contactsDiscoveryMock->method('__call')->with('basicApi')->willReturn($contactsApiMock);
$crmMock = $this->createMock(\HubSpot\Discovery\Crm\Discovery::class);
$crmMock->method('__call')->willReturnCallback(function ($name) use ($contactsDiscoveryMock) {
if ($name === 'contacts') {
return $contactsDiscoveryMock;
}
return $this->createMock(\HubSpot\Discovery\Crm\Properties\Discovery::class);
});
$discoveryMock = $this->createMock(\HubSpot\Discovery\Discovery::class);
$discoveryMock->method('__call')->with('crm')->willReturn($crmMock);
$client = $this->createPartialMock(Client::class, ['getNewInstance']);
$client->method('getNewInstance')->willReturn($discoveryMock);
$client->setLogger(new NullLogger());
$result = $client->getContactByEmail($email, $fields);
$this->assertEquals([
'id' => '12345',
'properties' => ['email' => '[EMAIL]'],
], $result);
}
public function testGetContactByEmailApiException(): void
{
$email = '[EMAIL]';
$fields = ['firstname', 'lastname'];
$exception = new \HubSpot\Client\Crm\Contacts\ApiException('Contact not found', 404);
$contactsApiMock = $this->createMock(\HubSpot\Client\Crm\Contacts\Api\BasicApi::class);
$contactsApiMock->expects($this->once())
->method('getById')
->with($email, 'firstname,lastname', null, false, 'email')
->willThrowException($exception);
$contactsDiscoveryMock = $this->createMock(\HubSpot\Discovery\Crm\Contacts\Discovery::class);
$contactsDiscoveryMock->method('__call')->with('basicApi')->willReturn($contactsApiMock);
$crmMock = $this->createMock(\HubSpot\Discovery\Crm\Discovery::class);
$crmMock->method('__call')->willReturnCallback(function ($name) use ($contactsDiscoveryMock) {
if ($name === 'contacts') {
return $contactsDiscoveryMock;
}
return $this->createMock(\HubSpot\Discovery\Crm\Properties\Discovery::class);
});
$discoveryMock = $this->createMock(\HubSpot\Discovery\Discovery::class);
$discoveryMock->method('__call')->with('crm')->willReturn($crmMock);
$loggerMock = $this->createMock(\Psr\Log\LoggerInterface::class);
$loggerMock->expects($this->once())
->method('info')
->with(
'[Hubspot] Failed to fetch contact',
[
'email' => $email,
'reason' => 'Contact not found',
]
);
$client = $this->createPartialMock(Client::class, ['getNewInstance']);
$client->method('getNewInstance')->willReturn($discoveryMock);
$client->setLogger($loggerMock);
$result = $client->getContactByEmail($email, $fields);
$this->assertEquals([], $result);
}
public function testGetOpportunityById(): void
{
$opportunityId = '12345';
$expectedProperties = [
'dealname' => 'Test Opportunity',
'amount' => '1000.00',
'closedate' => '2024-12-31T23:59:59.999Z',
'dealstage' => 'presentationscheduled',
'pipeline' => 'default',
];
$mockHubspotOpportunity = $this->createMock(DealWithAssociations::class);
$mockHubspotOpportunity->method('getProperties')->willReturn((object) $expectedProperties);
$mockHubspotOpportunity->method('getId')->willReturn($opportunityId);
$now = new \DateTimeImmutable();
$mockHubspotOpportunity->method('getCreatedAt')->willReturn($now);
$mockHubspotOpportunity->method('getUpdatedAt')->willReturn($now);
$mockHubspotOpportunity->method('getArchived')->willReturn(false);
$this->dealsBasicApiMock
->expects($this->once())
->method('getById')
->willReturn($mockHubspotOpportunity);
// Assuming Client::getOpportunityById processes the SimplePublicObject and returns an associative array.
// The structure might be like: ['id' => ..., 'properties' => [...], 'createdAt' => ..., ...]
// Adjust assertions below based on the actual return structure of your method.
$result = $this->client->getOpportunityById($opportunityId, ['test', 'test']);
$this->assertIsArray($result);
$this->assertArrayHasKey('id', $result);
$this->assertEquals($opportunityId, $result['id']);
}
public function testGetContactById(): void
{
$crmId = 'contact-123';
$fields = ['firstname', 'lastname'];
$expectedProperties = ['firstname' => 'John', 'lastname' => 'Doe'];
$mockContact = $this->createMock(\HubSpot\Client\Crm\Contacts\Model\SimplePublicObjectWithAssociations::class);
$mockContact->method('getId')->willReturn($crmId);
$mockContact->method('getProperties')->willReturn((object) $expectedProperties);
$contactsApiMock = $this->createMock(\HubSpot\Client\Crm\Contacts\Api\BasicApi::class);
$contactsApiMock->expects($this->once())
->method('getById')
->with($crmId, 'firstname,lastname')
->willReturn($mockContact);
$contactsDiscoveryMock = $this->createMock(\HubSpot\Discovery\Crm\Contacts\Discovery::class);
$contactsDiscoveryMock->method('__call')->with('basicApi')->willReturn($contactsApiMock);
$crmMock = $this->createMock(\HubSpot\Discovery\Crm\Discovery::class);
$crmMock->method('__call')->willReturnCallback(function ($name) use ($contactsDiscoveryMock) {
if ($name === 'contacts') {
return $contactsDiscoveryMock;
}
return $this->createMock(\HubSpot\Discovery\Crm\Properties\Discovery::class);
});
$discoveryMock = $this->createMock(\HubSpot\Discovery\Discovery::class);
$discoveryMock->method('__call')->with('crm')->willReturn($crmMock);
$client = $this->createPartialMock(Client::class, ['getNewInstance']);
$client->method('getNewInstance')->willReturn($discoveryMock);
$client->setLogger(new \Psr\Log\NullLogger());
$result = $client->getContactById($crmId, $fields);
$this->assertIsArray($result);
$this->assertArrayHasKey('id', $result);
$this->assertArrayHasKey('properties', $result);
$this->assertEquals($crmId, $result['id']);
$this->assertEquals((object) $expectedProperties, $result['properties']);
}
public function testGetAccountById(): void
{
$crmId = 'account-123';
$fields = ['name', 'industry'];
$expectedProperties = ['name' => 'Acme Corp', 'industry' => 'Technology'];
$mockCompany = $this->createMock(\HubSpot\Client\Crm\Companies\Model\SimplePublicObjectWithAssociations::class);
$mockCompany->method('getId')->willReturn($crmId);
$mockCompany->method('getProperties')->willReturn((object) $expectedProperties);
$companiesApiMock = $this->createMock(\HubSpot\Client\Crm\Companies\Api\BasicApi::class);
$companiesApiMock->expects($this->once())
->method('getById')
->with($crmId, 'name,industry')
->willReturn($mockCompany);
$companiesDiscoveryMock = $this->createMock(\HubSpot\Discovery\Crm\Companies\Discovery::class);
$companiesDiscoveryMock->method('__call')->with('basicApi')->willReturn($companiesApiMock);
$crmMock = $this->createMock(\HubSpot\Discovery\Crm\Discovery::class);
$crmMock->method('__call')->willReturnCallback(function ($name) use ($companiesDiscoveryMock) {
if ($name === 'companies') {
return $companiesDiscoveryMock;
}
return $this->createMock(\HubSpot\Discovery\Crm\Properties\Discovery::class);
});
$discoveryMock = $this->createMock(\HubSpot\Discovery\Discovery::class);
$discoveryMock->method('__call')->with('crm')->willReturn($crmMock);
$client = $this->createPartialMock(Client::class, ['getNewInstance']);
$client->method('getNewInstance')->willReturn($discoveryMock);
$client->setLogger(new \Psr\Log\NullLogger());
$result = $client->getAccountById($crmId, $fields);
$this->assertIsArray($result);
$this->assertArrayHasKey('id', $result);
$this->assertArrayHasKey('properties', $result);
$this->assertEquals($crmId, $result['id']);
$this->assertEquals((object) $expectedProperties, $result['properties']);
}
public function testEnsureValidTokenWithNoTokenUpdate(): void
{
$socialAccountMock = $this->createMock(SocialAccount::class);
// Set up OAuth account
$reflection = new \ReflectionClass($this->client);
$oauthAccountProperty = $reflection->getProperty('oauthAccount');
$oauthAccountProperty->setAccessible(true);
$oauthAccountProperty->setValue($this->client, $socialAccountMock);
$originalToken = 'original_token';
$accessTokenProperty = $reflection->getProperty('accessToken');
$accessTokenProperty->setAccessible(true);
$accessTokenProperty->setValue($this->client, $originalToken);
// Mock token manager to return null (no refresh needed)
$this->tokenManagerMock
->expects($this->once())
->method('ensureValidToken')
->with($socialAccountMock)
->willReturn(null);
// Call ensureValidToken
$this->client->ensureValidToken();
// Verify access token was not changed
$this->assertEquals($originalToken, $accessTokenProperty->getValue($this->client));
}
public function testGetPaginatedDataGeneratorDelegatesToPaginationService(): void
{
$payload = ['filters' => []];
$type = 'contacts';
$offset = 0;
$total = 0;
$lastRecordId = null;
$expectedResults = [
['id' => 'id_1', 'properties' => []],
['id' => 'id_2', 'properties' => []],
];
// Mock the pagination service to return a generator
$this->paginationServiceMock
->expects($this->once())
->method('getPaginatedDataGenerator')
->with(
$this->client,
$payload,
$type,
$offset,
$this->anything(),
$this->anything()
)
->willReturnCallback(function () use ($expectedResults) {
foreach ($expectedResults as $result) {
yield $result;
}
});
// Execute the pagination
$results = [];
foreach ($this->client->getPaginatedDataGenerator($payload, $type, $offset, $total, $lastRecordId) as $result) {
$results[] = $result;
}
$this->assertCount(2, $results);
$this->assertEquals('id_1', $results[0]['id']);
$this->assertEquals('id_2', $results[1]['id']);
}
public function testEnsureValidTokenDelegatesToTokenManager(): void
{
$socialAccountMock = $this->createMock(SocialAccount::class);
// Set up OAuth account
$reflection = new \ReflectionClass($this->client);
$oauthAccountProperty = $reflection->getProperty('oauthAccount');
$oauthAccountProperty->setAccessible(true);
$oauthAccountProperty->setValue($this->client, $socialAccountMock);
// Mock token manager to return new token
$this->tokenManagerMock
->expects($this->once())
->method('ensureValidToken')
->with($socialAccountMock)
->willReturn('new_access_token');
// Call ensureValidToken
$this->client->ensureValidToken();
// Verify access token was updated
$accessTokenProperty = $reflection->getProperty('accessToken');
$accessTokenProperty->setAccessible(true);
$this->assertEquals('new_access_token', $accessTokenProperty->getValue($this->client));
}
public function testGetOwnersArchivedWithValidResponse(): void
{
$responseData = [
'results' => [
[
'id' => '123',
'email' => '[EMAIL]',
'type' => 'PERSON',
'firstName' => 'John',
'lastName' => 'Doe',
'userId' => 456,
'userIdIncludingInactive' => 789,
'createdAt' => '2023-01-01T12:00:00Z',
'updatedAt' => '2023-01-02T12:00:00Z',
'archived' => true,
],
],
];
// Create a mock response object
$response = $this->createMock(\SevenShores\Hubspot\Http\Response::class);
$response->method('toArray')
->willReturn($responseData);
// Set up the client to return our test data
$this->client->method('makeRequest')
->with(
'/crm/v3/owners',
'GET',
[],
'archived=true'
)
->willReturn($response);
// Call the method
$result = $this->client->getOwnersArchived(true);
// Assert the results
$this->assertCount(1, $result);
$this->assertEquals('123', $result[0]->getId());
$this->assertEquals('[EMAIL]', $result[0]->getEmail());
$this->assertEquals('John Doe', $result[0]->getFullName());
$this->assertTrue($result[0]->isArchived());
}
public function testGetOwnersArchivedWithEmptyResponse(): void
{
// Create a mock response object with empty results
$response = $this->createMock(\SevenShores\Hubspot\Http\Response::class);
$response->method('toArray')
->willReturn(['results' => []]);
// Set up the client to return empty results
$this->client->method('makeRequest')
->with(
'/crm/v3/owners',
'GET',
[],
'archived=false'
)
->willReturn($response);
// Call the method
$result = $this->client->getOwnersArchived(false);
// Assert the results
$this->assertIsArray($result);
$this->assertEmpty($result);
}
public function testGetOwnersArchivedWithInvalidResponse(): void
{
// Create a mock response that will throw an exception when toArray is called
$response = $this->createMock(\SevenShores\Hubspot\Http\Response::class);
$response->method('toArray')
->willThrowException(new \InvalidArgumentException('Invalid JSON'));
// Set up the client to return the problematic response
$this->client->method('makeRequest')
->willReturn($response);
// Mock the logger to expect an error message
$loggerMock = $this->createMock(\Psr\Log\LoggerInterface::class);
$loggerMock->expects($this->once())
->method('error')
->with($this->stringContains('Failed to fetch owners'));
$reflection = new \ReflectionClass($this->client);
$loggerProperty = $reflection->getProperty('log');
$loggerProperty->setAccessible(true);
$loggerProperty->setValue($this->client, $loggerMock);
// Call the method and expect an empty array on error
$result = $this->client->getOwnersArchived(true);
$this->assertIsArray($result);
$this->assertEmpty($result);
}
public function testGetOwnersArchivedWithHttpError(): void
{
// Set up the client to throw an exception
$this->client->method('makeRequest')
->willThrowException(new \Exception('HTTP Error'));
// Mock the logger to expect an error message
$loggerMock = $this->createMock(\Psr\Log\LoggerInterface::class);
$loggerMock->expects($this->once())
->method('error')
->with($this->stringContains('Failed to fetch owners'));
$reflection = new \ReflectionClass($this->client);
$loggerProperty = $reflection->getProperty('log');
$loggerProperty->setAccessible(true);
$loggerProperty->setValue($this->client, $loggerMock);
// Call the method and expect an empty array on error
$result = $this->client->getOwnersArchived(false);
$this->assertIsArray($result);
$this->assertEmpty($result);
}
public function testGetOwnersArchivedWithOwnerCreationException(): void
{
$responseData = [
'results' => [
[
'id' => '123',
'email' => '[EMAIL]',
'type' => 'PERSON',
'firstName' => 'John',
'lastName' => 'Doe',
'userId' => 456,
'userIdIncludingInactive' => 789,
'createdAt' => '2023-01-01T12:00:00Z',
'updatedAt' => '2023-01-02T12:00:00Z',
'archived' => false,
],
[
'id' => '456',
'email' => '[EMAIL]',
'type' => 'PERSON',
'createdAt' => 'invalid-date-format',
],
[
'id' => '789',
'email' => '[EMAIL]',
'type' => 'PERSON',
'firstName' => 'Jane',
'lastName' => 'Smith',
'userId' => 999,
'userIdIncludingInactive' => 888,
'createdAt' => '2023-01-03T12:00:00Z',
'updatedAt' => '2023-01-04T12:00:00Z',
'archived' => false,
],
],
];
$response = $this->createMock(\SevenShores\Hubspot\Http\Response::class);
$response->method('toArray')
->willReturn($responseData);
$this->client->method('makeRequest')
->with(
'/crm/v3/owners',
'GET',
[],
'archived=false'
)
->willReturn($response);
$loggerMock = $this->createMock(\Psr\Log\LoggerInterface::class);
$loggerMock->expects($this->once())
->method('error')
->with(
'[HubSpot] Failed to process owner data',
$this->callback(function ($context) {
return isset($context['result']) &&
isset($context['error']) &&
$context['result']['id'] === '456' &&
$context['result']['email'] === '[EMAIL]' &&
str_contains($context['error'], 'invalid-date-format');
})
);
$reflection = new \ReflectionClass($this->client);
$loggerProperty = $reflection->getProperty('log');
$loggerProperty->setAccessible(true);
$loggerProperty->setValue($this->client, $loggerMock);
$result = $this->client->getOwnersArchived(false);
$this->assertIsArray($result);
$this->assertCount(2, $result);
$this->assertEquals('123', $result[0]->getId());
$this->assertEquals('[EMAIL]', $result[0]->getEmail());
$this->assertEquals('789', $result[1]->getId());
$this->assertEquals('[EMAIL]', $result[1]->getEmail());
}
public function testMakeRequestWithGetMethod(): void
{
$socialAccountService = $this->createMock(SocialAccountService::class);
$paginationService = $this->createMock(HubspotPaginationService::class);
$tokenManager = $this->createMock(HubspotTokenManager::class);
$psrResponse = new Response(200, [], json_encode(['status' => 'success']));
$expectedResponse = new HubspotResponse($psrResponse);
$hubspotClientMock = $this->createMock(HubspotClient::class);
$hubspotClientMock->expects($this->once())
->method('request')
->with(
'GET',
'https://api.hubapi.com/crm/v3/objects/contacts',
[],
null,
true
)
->willReturn($expectedResponse);
$factoryMock = $this->createMock(Factory::class);
$factoryMock->method('getClient')->willRetu...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
5 files, folder partially checked
app/Console/Commands 1 file, folder not checked
config 1 file, folder not checked
tests/Unit 2 files, folder checked
Jobs/Crm 1 file, folder checked
MatchActivityCrmDataTest.php, class checked
Services/Crm/Hubspot/Pagination 1 file, folder checked
HubspotPaginationServiceTest.php, class checked
.env.local not checked
app/Console/Commands 1 file, folder not checked
config 1 file, folder not checked
tests/Unit 2 files, folder checked
Jobs/Crm 1 file, folder checked
MatchActivityCrmDataTest.php, class checked
Services/Crm/Hubspot/Pagination 1 file, folder checked
HubspotPaginationServiceTest.php, class checked
Jobs/Crm 1 file, folder checked
MatchActivityCrmDataTest.php, class checked
MatchActivityCrmDataTest.php, class checked
Services/Crm/Hubspot/Pagination 1 file, folder checked
HubspotPaginationServiceTest.php, class checked
HubspotPaginationServiceTest.php, class checked
.env.local not checked
Unversioned Files 9 files not checked
2 modified
JY-20725 add HS rate limit handling on activities rematching
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference
Next Difference
Jump to Source
Compare Previous File
Compare Next File
Go to Changed File…
Side-by-side viewer
Do not ignore
Highlight words
Collapse Unchanged Fragments
Synchronize Scrolling
Disable Editing
Settings
Help
4 differences
44d5678c
<?php
declare(strict_types=1);
namespace Tests\Unit\Jobs\Crm;
use Illuminate\Database\Connection;
use Illuminate\Database\Eloquent\Relations\HasMany;
use Jiminny\Exceptions\InvalidArgumentException;
use Jiminny\Jobs\Crm\MatchActivityCrmData;
use Jiminny\Models\Account;
use Jiminny\Models\Activity;
use Jiminny\Models\Contact;
use Jiminny\Models\Crm\Configuration;
use Jiminny\Models\Lead;
use Jiminny\Models\Opportunity;
use Jiminny\Models\Stage;
use Jiminny\Models\Team;
use Jiminny\Models\User;
use Jiminny\Repositories\ActivityRepository;
use Jiminny\Services\Crm\CrmActivityService;
use PHPUnit\Framework\MockObject\Exception;
use PHPUnit\Framework\MockObject\MockObject;
use Tests\TestCase;
class MatchActivityCrmDataTest extends TestCase
{
private ActivityRepository|MockObject $activityRepository;
private CrmActivityService|MockObject $crmActivityService;
private Connection|MockObject $connection;
protected function setUp(): void
{
parent::setUp();
$this->activityRepository = $this->createMock(ActivityRepository::class);
$this->crmActivityService = $this->createMock(CrmActivityService::class);
$this->connection = $this->createMock(Connection::class);
}
/**
* @throws \Exception|Exception
*/
public function testHandle(): void
{
$fromConfiguration = $this->createMock(Configuration::class);
$fromConfiguration->method('getId')->willReturn(5);
$team = $this->createMock(Team::class);
$user = $this->createMock(User::class);
$user->method('getTeam')->willReturn($team);
$activityConfiguration = $this->createMock(Configuration::class);
$activityConfiguration->method('getId')->willReturn(10);
$participants = $this->createMock(HasMany::class);
$activity = $this->createMock(Activity::class);
$activity->method('getUuid')->willReturn('test');
$activity->method('getProvider')->willReturn('provider');
$activity->method('getUser')->willReturn($user);
$activity->method('getCrm')->willReturn($activityConfiguration);
$activity->method('participants')->willReturn($participants);
$activity->expects($this->exactly(2))->method('update');
$this->activityRepository->expects(($this->once()))
->method('findById')
->with(1)
->willReturn($activity);
$this->activityRepository->expects($this->once())
->method('getActivityParticipants')
->with($activity)
->willReturn(collect([]));
$this->crmActivityService->expects($this->once())
->method('updateCrmData')
->with($activity, false);
$this->connection->expects($this->once())
->method('transaction')
->willReturnCallback(function ($callback) {
return $callback();
});
$job = new MatchActivityCrmData(
activityId: 1,
fromConfiguration: $fromConfiguration,
);
$job->handle(
activityRepository: $this->activityRepository,
crmActivityService: $this->crmActivityService,
connection: $this->connection,
);
}
/**
* @throws \Exception|Exception
*/
public function testHandleNoActivity(): void
{
$this->activityRepository->expects(($this->once()))
->method('findById')
->with(1)
->willReturn(null);
$job = new MatchActivityCrmData(
activityId: 1,
fromConfiguration: null,
);
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage('[MatchActivityCrmData] Cannot find activity.');
$job->handle(
activityRepository: $this->activityRepository,
crmActivityService: $this->crmActivityService,
connection: $this->connection,
);
}
public function testSkipsCrmConfigurationSwitchWhenAlreadyMatches(): void
{
$fromConfiguration = $this->createMock(Configuration::class);
$fromConfiguration->method('getId')->willReturn(5);
$activityConfiguration = $this->createMock(Configuration::class);
$activityConfiguration->method('getId')->willReturn(5);
$participants = $this->createMock(HasMany::class);
$activity = $this->createMock(Activity::class);
$activity->method('getCrm')->willReturn($activityConfiguration);
$activity->method('participants')->willReturn($participants);
$activity->expects($this->once())->method('update');
$this->activityRepository->expects($this->once())
->method('findById')
->with(123)
->willReturn($activity);
$this->activityRepository->expects($this->once())
->method('getActivityParticipants')
->with($activity)
->willReturn(collect([]));
$this->crmActivityService->expects($this->once())
->method('updateCrmData')
->with($activity, false);
$this->connection->expects($this->once())
->method('transaction')
->willReturnCallback(function ($callback) {
return $callback();
});
$job = new MatchActivityCrmData(
activityId: 123,
fromConfiguration: $fromConfiguration,
);
$job->handle(
activityRepository: $this->activityRepository,
crmActivityService: $this->crmActivityService,
connection: $this->connection,
);
}
public function testJobConfiguration(): void
{
$job = new MatchActivityCrmData(
activityId: 1,
fromConfiguration: null,
remoteSearch: false,
);
$this->assertSame(3, $job->tries);
$this->assertSame(300, $job->timeout());
$this->assertSame(360, $job->uniqueFor());
$this->assertSame([30, 90, 180], $job->backoff());
}
public function testUniqueId(): void
{
$configuration = $this->createMock(Configuration::class);
$configuration->method('getId')->willReturn(5);
$job1 = new MatchActivityCrmData(
activityId: 123,
fromConfiguration: null,
remoteSearch: false,
);
$this->assertSame('123:0:local', $job1->uniqueId());
$job2 = new MatchActivityCrmData(
activityId: 123,
fromConfiguration: null,
remoteSearch: true,
);
$this->assertSame('123:0:remote', $job2->uniqueId());
$job3 = new MatchActivityCrmData(
activityId: 123,
fromConfiguration: $configuration,
remoteSearch: false,
);
$this->assertSame('123:5:local', $job3->uniqueId());
}
public function testTransactionRollbackOnException(): void
{
$activity = $this->createMock(Activity::class);
$this->activityRepository->expects($this->once())
->method('findById')
->with(1)
->willReturn($activity);
$exception = new \RuntimeException('Test exception');
$this->connection->expects($this->once())
->method('transaction')
->willReturnCallback(function ($callback) use ($exception) {
throw $exception;
});
$job = new MatchActivityCrmData(
activityId: 1,
fromConfiguration: null,
);
$this->expectException(\RuntimeException::class);
$this->expectExceptionMessage('Test exception');
$job->handle(
activityRepository: $this->activityRepository,
crmActivityService: $this->crmActivityService,
connection: $this->connection,
);
}
public function testFailedMethodLogsError(): void
{
$exception = new \RuntimeException('Test failure');
$job = new MatchActivityCrmData(
activityId: 123,
fromConfiguration: null,
remoteSearch: true,
);
$job->failed($exception);
$this->assertTrue(true);
}
public function testLogsSuccessWhenMatchFound(): void
{
$participants = $this->createMock(HasMany::class);
$lead = $this->createMock(Lead::class);
$lead->method('getId')->willReturn(456);
$activity = $this->createMock(Activity::class);
$activity->method('participants')->willReturn($participants);
$activity->method('getLead')->willReturn($lead);
$activity->method('getContact')->willReturn(null);
$activity->method('getAccount')->willReturn(null);
$activity->method('getOpportunity')->willReturn(null);
$this->activityRepository->expects($this->once())
->method('findById')
->with(123)
->willReturn($activity);
$this->activityRepository->expects($this->once())
->method('getActivityParticipants')
->with($activity)
->willReturn(collect([]));
$this->crmActivityService->expects($this->once())
->method('updateCrmData')
->with($activity, false);
$this->connection->expects($this->once())
->method('transaction')
->willReturnCallback(function ($callback) {
return $callback();
});
$job = new MatchActivityCrmData(
activityId: 123,
fromConfiguration: null,
remoteSearch: false,
);
$job->handle(
activityRepository: $this->activityRepository,
crmActivityService: $this->crmActivityService,
connection: $this->connection,
);
}
public function testLogsNoMatchWhenNoMatchFound(): void
{
$participants = $this->createMock(HasMany::class);
$activity = $this->createMock(Activity::class);
$activity->method('participants')->willReturn($participants);
$activity->method('getLead')->willReturn(null);
$activity->method('getContact')->willReturn(null);
$activity->method('getAccount')->willReturn(null);
$activity->method('getOpportunity')->willReturn(null);
$this->activityRepository->expects($this->once())
->method('findById')
->with(123)
->willReturn($activity);
$this->activityRepository->expects($this->once())
->method('getActivityParticipants')
->with($activity)
->willReturn(collect([]));
$this->crmActivityService->expects($this->once())
->method('updateCrmData')
->with($activity, true);
$this->connection->expects($this->once())
->method('transaction')
->willReturnCallback(function ($callback) {
return $callback();
});
$job = new MatchActivityCrmData(
activityId: 123,
fromConfiguration: null,
remoteSearch: true,
);
$job->handle(
activityRepository: $this->activityRepository,
crmActivityService: $this->crmActivityService,
connection: $this->connection,
);
}
public function testLogsOldStateBeforeClearing(): void
{
$participant1 = new \stdClass();
$participant1->id = 10;
$participant1->user_id = 100;
$participant1->contact_id = 200;
$participant1->lead_id = null;
$participant2 = new \stdClass();
$participant2->id = 20;
$participant2->user_id = null;
$participant2->contact_id = null;
$participant2->lead_id = 300;
$participantsCollection = collect([$participant1, $participant2]);
$participantsRelation = $this->createMock(HasMany::class);
$lead = $this->createMock(Lead::class);
$lead->method('getId')->willReturn(111);
$contact = $this->createMock(Contact::class);
$contact->method('getId')->willReturn(222);
$account = $this->createMock(Account::class);
$account->method('getId')->willReturn(333);
$opportunity = $this->createMock(Opportunity::class);
$opportunity->method('getId')->willReturn(444);
$stage = $this->createMock(Stage::class);
$stage->method('getId')->willReturn(555);
$activity = $this->createMock(Activity::class);
$activity->method('participants')->willReturn($participantsRelation);
$activity->method('getLead')->willReturn($lead);
$activity->method('getContact')->willReturn($contact);
$activity->method('getAccount')->willReturn($account);
$activity->method('getOpportunity')->willReturn($opportunity);
$activity->method('getStage')->willReturn($stage);
$this->activityRepository->expects($this->once())
->method('findById')
->with(999)
->willReturn($activity);
$this->activityRepository->expects($this->once())
->method('getActivityParticipants')
->with($activity)
->willReturn($participantsCollection);
$this->crmActivityService->expects($this->once())
->method('updateCrmData')
->with($activity, false);
$this->connection->expects($this->once())
->method('transaction')
->willReturnCallback(function ($callback) {
return $callback();
});
$job = new MatchActivityCrmData(
activityId: 999,
fromConfiguration: null,
remoteSearch: false,
);
$job->handle(
activityRepository: $this->activityRepository,
crmActivityService: $this->crmActivityService,
connection: $this->connection,
);
}
}...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
5 modified
Analyzing…
JY-20725 code review suggestions
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference...
|
PhpStorm
|
Commit Changes
|
NULL
|
|
Diff
Changelist:
Changelist:
Changes
Show Diff
Rol Diff
Changelist:
Changelist:
Changes
Show Diff
Rollback...
Refresh
Group By
Expand All
Collapse All
5 modified
Analyzing…
JY-20725 code review suggestions
Commit Message
Commit Message History
Git
Author:
Author:
Amend commit
Sign-off commit
Create extra commit with file movements
Commit Checks
Update copyright
Reformat code
Rearrange code
Optimize imports
Cleanup
Choose profile
Check malicious dependencies
Run external formatter
Configure
Perform SonarQube for IDE analysis
Find unused view files
Run Git hooks
Advanced Commit Checks
Analyze code
Choose profile
Check TODO
Configure
After Commit
Upload files to:
Upload files to:
<None>
Always use selected server or group of servers
Previous Difference
Next Difference...
|
PhpStorm
|
Commit Changes
|
NULL
|