|
Cart
Pull requests · screenpipe/screenpipe · GitHu Cart
Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
VIVACOM
VIVACOM
Смартфони от Vivacom – открийте най-новите модели
Смартфони от Vivacom – открийте най-новите модели
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
Премини към основното съдържание
Активиране на достъпност за хора със слабо зрение
Отворете менюто за достъпност
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Преподпиши своята мобилна услуга онлайн
Преподпиши своята мобилна услуга онлайн
Виж предложенията за преподписване за твоите услуги
Виж офертите - отвори в нов раздел
Виж офертите
Виж офертите
Next slide
филтри
Сортирай по
избери опция
избери опция
УСТРОЙСТВА (29)
УСТРОЙСТВА (29)
Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE Front Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE 128GB 14.32€ | 28.01лв. /мес. Previous price was €15.99 | 31.27лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 259.99€ | 508.50лв.
Samsung
SAMSUNG GALAXY A37 5G 128GB
SAMSUNG GALAXY A37 5G 128GB
AWESOME WHITE 128GB
14.32€
|
28.01лв.
/мес.
|
31.27лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
259.99€ | 508.50лв.
Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE Front Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE 128GB 15.32€ | 29.96лв. /мес. Previous price was €16.99 | 33.23лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 289.99€ | 567.17лв.
Samsung
SAMSUNG GALAXY A57 5G 128GB
SAMSUNG GALAXY A57 5G 128GB
AWESOME ICEBLUE 128GB
15.32€
|
29.96лв.
/мес.
|
33.23лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
289.99€ | 567.17лв.
Избор на цвят AWESOME GRAY Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY Front Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY 256GB 17.32€ | 33.87лв. /мес. Previous price was €18.99 | 37.14лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 349.99€ | 684.52лв.
Samsung
SAMSUNG GALAXY A57 5G 256GB
SAMSUNG GALAXY A57 5G 256GB
AWESOME GRAY 256GB
17.32€
|
33.87лв.
/мес.
|
37.14лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
349.99€ | 684.52лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26 ULTRA 256GB BLACK Front Samsung SAMSUNG GALAXY S26 ULTRA 256GB BLACK 256GB 55.99€ | 109.51лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1149.99€ | 2249.18лв.
Samsung
SAMSUNG GALAXY S26 ULTRA 256GB
SAMSUNG GALAXY S26 ULTRA 256GB
BLACK 256GB
55.99€
|
109.51лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1149.99€ | 2249.18лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26 ULTRA 512GB BLACK Front Samsung SAMSUNG GALAXY S26 ULTRA 512GB BLACK 512GB 65.99€ | 129.07лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1349.99€ | 2640.35лв.
Samsung
SAMSUNG GALAXY S26 ULTRA 512GB
SAMSUNG GALAXY S26 ULTRA 512GB
BLACK 512GB
65.99€
|
129.07лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1349.99€ | 2640.35лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26 ULTRA 1TB BLACK Front Samsung SAMSUNG GALAXY S26 ULTRA 1TB BLACK 1TB 80.99€ | 158.40лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1649.99€ | 3227.10лв.
Samsung
SAMSUNG GALAXY S26 ULTRA 1TB
SAMSUNG GALAXY S26 ULTRA 1TB
BLACK 1TB
80.99€
|
158.40лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1649.99€ | 3227.10лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26+ 256GB BLACK Front Samsung SAMSUNG GALAXY S26+ 256GB BLACK 256GB 46.99€ | 91.90лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 949.99€ | 1858.02лв.
Samsung
SAMSUNG GALAXY S26+ 256GB
SAMSUNG GALAXY S26+ 256GB
BLACK 256GB
46.99€
|
91.90лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
949.99€ | 1858.02лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26+ 512GB BLACK Front Samsung SAMSUNG GALAXY S26+ 512GB BLACK 512GB 55.99€ | 109.51лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1149.99€ | 2249.18лв.
Samsung
SAMSUNG GALAXY S26+ 512GB
SAMSUNG GALAXY S26+ 512GB
BLACK 512GB
55.99€
|
109.51лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1149.99€ | 2249.18лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26 256GB BLACK Front Samsung SAMSUNG GALAXY S26 256GB BLACK 256GB 38.99€ | 76.26лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 799.99€ | 1564.64лв.
Samsung
SAMSUNG GALAXY S26 256GB
SAMSUNG GALAXY S26 256GB
BLACK 256GB
38.99€
|
76.26лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
799.99€ | 1564.64лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26 512GB BLACK Front Samsung SAMSUNG GALAXY S26 512GB BLACK 512GB 43.99€ | 86.04лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 899.99€ | 1760.23лв.
Samsung
SAMSUNG GALAXY S26 512GB
SAMSUNG GALAXY S26 512GB
BLACK 512GB
43.99€
|
86.04лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
899.99€ | 1760.23лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY A26 5G 128GB BLACK Front Samsung SAMSUNG GALAXY A26 5G 128GB BLACK 128GB 5.99€ | 11.72лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 119.99€ | 234.68лв.
Samsung
SAMSUNG GALAXY A26 5G 128GB
SAMSUNG GALAXY A26 5G 128GB
BLACK 128GB
5.99€
|
11.72лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
119.99€ | 234.68лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY Z FLIP7 FE 256GB BLACK Front Samsung SAMSUNG GALAXY Z FLIP7 FE 256GB BLACK 256GB 26.99€ | 52.79лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 549.99€ | 1075.69лв.
Samsung
SAMSUNG GALAXY Z FLIP7 FE 256GB
SAMSUNG GALAXY Z FLIP7 FE 256GB
BLACK 256GB
26.99€
|
52.79лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
549.99€ | 1075.69лв.
Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Samsung SAMSUNG GALAXY A36 5G 128GB AWESOME WHITE Front Samsung SAMSUNG GALAXY A36 5G 128GB AWESOME WHITE 128GB 7.99€ | 15.63лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 139.99€ | 273.80лв.
Samsung
SAMSUNG GALAXY A36 5G 128GB
SAMSUNG GALAXY A36 5G 128GB
AWESOME WHITE 128GB
7.99€
|
15.63лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
139.99€ | 273.80лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY A17 5G 128GB BLACK Front Samsung SAMSUNG GALAXY A17 5G 128GB BLACK 128GB 2.99€ | 5.85лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 59.99€ | 117.33лв.
Samsung
SAMSUNG GALAXY A17 5G 128GB
SAMSUNG GALAXY A17 5G 128GB
BLACK 128GB
2.99€
|
5.85лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
59.99€ | 117.33лв.
Избор на цвят JETBLACK Samsung SAMSUNG GALAXY S25 FE 5G 128GB JETBLACK Front Samsung SAMSUNG GALAXY S25 FE 5G 128GB JETBLACK 128GB 19.99€ | 39.10лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 399.99€ | 782.31лв.
Samsung
SAMSUNG GALAXY S25 FE 5G 128GB
SAMSUNG GALAXY S25 FE 5G 128GB
JETBLACK 128GB
19.99€
|
39.10лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
399.99€ | 782.31лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW 512GB 41.67€ | 81.50лв. /мес. 46.99€ | 91.90лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 999.99€ | 1955.81лв.
Samsung
SAMSUNG GALAXY Z FLIP7 512GB
SAMSUNG GALAXY Z FLIP7 512GB
BLUE SHADOW 512GB
41.67€
|
81.50лв.
/мес.
46.99€
|
91.90лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
999.99€ | 1955.81лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW 256GB 60.42€ | 118.17лв. /мес. 70.99€ | 138.84лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1449.99€ | 2835.93лв.
Samsung
SAMSUNG GALAXY Z FOLD7 256GB
SAMSUNG GALAXY Z FOLD7 256GB
SILVER SHADOW 256GB
60.42€
|
118.17лв.
/мес.
70.99€
|
138.84лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1449.99€ | 2835.93лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW 512GB 66.67€ | 130.40лв. /мес. 77.99€ | 152.54лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1599.99€ | 3129.31лв.
Samsung
SAMSUNG GALAXY Z FOLD7 512GB
SAMSUNG GALAXY Z FOLD7 512GB
SILVER SHADOW 512GB
66.67€
|
130.40лв.
/мес.
77.99€
|
152.54лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1599.99€ | 3129.31лв.
Избор на цвят TITANIUM ICYBLUE Избор на цвят TITANIUM ICYBLUE Samsung SAMSUNG GALAXY S25 EDGE 5G 256GB TITANIUM ICYBLUE Front Samsung SAMSUNG GALAXY S25 EDGE 5G 256GB TITANIUM ICYBLUE 256GB 34.99€ | 68.43лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 709.99€ | 1388.62лв.
Samsung
SAMSUNG GALAXY S25 EDGE 5G 256GB
SAMSUNG GALAXY S25 EDGE 5G 256GB
TITANIUM ICYBLUE 256GB
34.99€
|
68.43лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
709.99€ | 1388.62лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW 1TB 78.33€ | 153.20лв. /мес. 92.99€ | 181.87лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1879.99€ | 3676.94лв.
Samsung
SAMSUNG GALAXY Z FOLD7 1TB
SAMSUNG GALAXY Z FOLD7 1TB
BLUE SHADOW 1TB
78.33€
|
153.20лв.
/мес.
92.99€
|
181.87лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1879.99€ | 3676.94лв.
В комплект с протектор Избор на цвят AWESOME GRAPHITE Избор на цвят AWESOME GRAPHITE Избор на цвят AWESOME GRAPHITE Избор на цвят AWESOME GRAPHITE Samsung Samsung Galaxy A56 5G 128GB + Протектор AWESOME GRAPHITE Front Samsung Samsung Galaxy A56 5G 128GB + Протектор AWESOME GRAPHITE 128GB 12.26€ | 23.98лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 245.41€ | 479.98лв.
В комплект с протектор
Samsung
Samsung Galaxy A56 5G 128GB + Протектор
Samsung Galaxy A56 5G 128GB + Протектор
AWESOME GRAPHITE 128GB
12.26€
|
23.98лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
245.41€ | 479.98лв.
Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Samsung SAMSUNG GALAXY S25 ULTRA 512GB TITANIUM BLACK Front Samsung SAMSUNG GALAXY S25 ULTRA 512GB TITANIUM BLACK 512GB 42.99€ | 84.08лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 869.99€ | 1701.55лв.
Samsung
SAMSUNG GALAXY S25 ULTRA 512GB
SAMSUNG GALAXY S25 ULTRA 512GB
TITANIUM BLACK 512GB
42.99€
|
84.08лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
869.99€ | 1701.55лв.
Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Samsung SAMSUNG GALAXY S25 ULTRA 1TB TITANIUM BLACK Front Samsung SAMSUNG GALAXY S25 ULTRA 1TB TITANIUM BLACK 1TB 55.99€ | 109.51лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1139.99€ | 2229.63лв.
Samsung
SAMSUNG GALAXY S25 ULTRA 1TB
SAMSUNG GALAXY S25 ULTRA 1TB
TITANIUM BLACK 1TB
55.99€
|
109.51лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1139.99€ | 2229.63лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK Front Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK 128GB 20.83€ | 40.74лв. /мес. 23.99€ | 46.92лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 499.99€ | 977.90лв.
Samsung
SAMSUNG GALAXY Z FLIP7 FE 128GB
SAMSUNG GALAXY Z FLIP7 FE 128GB
BLACK 128GB
20.83€
|
40.74лв.
/мес.
23.99€
|
46.92лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
499.99€ | 977.90лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW 256GB 37.50€ | 73.34лв. /мес. 42.99€ | 84.08лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 899.99€ | 1760.23лв.
Samsung
SAMSUNG GALAXY Z FLIP7 256GB
SAMSUNG GALAXY Z FLIP7 256GB
BLUE SHADOW 256GB
37.50€
|
73.34лв.
/мес.
42.99€
|
84.08лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
899.99€ | 1760.23лв.
Избор на цвят BLACK Samsung SAMSUNG GALAXY XCOVER 7 PRO 128GB BLACK Front Samsung SAMSUNG GALAXY XCOVER 7 PRO 128GB BLACK 128GB 12.99€ | 25.41лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 259.99€ | 508.50лв.
Samsung
SAMSUNG GALAXY XCOVER 7 PRO 128GB
SAMSUNG GALAXY XCOVER 7 PRO 128GB
BLACK 128GB
12.99€
|
25.41лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
259.99€ | 508.50лв.
Избор на цвят LIGHT GREEN Samsung SAMSUNG GALAXY A16 4G 128GB LIGHT GREEN Front Samsung SAMSUNG GALAXY A16 4G 128GB LIGHT GREEN 128GB 1.99€ | 3.89лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 29.99€ | 58.66лв.
Samsung
SAMSUNG GALAXY A16 4G 128GB
SAMSUNG GALAXY A16 4G 128GB
LIGHT GREEN 128GB
1.99€
|
3.89лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
29.99€ | 58.66лв.
Избор на цвят MINT Избор на цвят MINT Избор на цвят MINT Избор на цвят MINT Избор на цвят MINT Samsung SAMSUNG GALAXY S25 256GB MINT Front Samsung SAMSUNG GALAXY S25 256GB MINT 256GB 26.99€ | 52.79лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 539.99€ | 1056.13лв.
Samsung
SAMSUNG GALAXY S25 256GB
SAMSUNG GALAXY S25 256GB
MINT 256GB
26.99€
|
52.79лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
539.99€ | 1056.13лв.
Избор на цвят MINT Избор на цвят MINT Избор на цвят MINT Избор на цвят MINT Samsung SAMSUNG GALAXY S25 512GB MINT Front Samsung SAMSUNG GALAXY S25 512GB MINT 512GB 32.99€ | 64.52лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 669.99€ | 1310.39лв.
Samsung
SAMSUNG GALAXY S25 512GB
SAMSUNG GALAXY S25 512GB
MINT 512GB
32.99€
|
64.52лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
669.99€ | 1310.39лв.
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия
Общи условия
Общи условия
Мобилно покритие
Мобилно покритие
Лични данни
Лични данни
Правила за ползване
Правила за ползване
Роуминг
Роуминг
Политика за бисквитките
Политика за бисквитките
Полезни връзки
Полезни връзки
Устройство в сервиз
Устройство в сервиз
Спешни номера
Спешни номера
Активиране на EON TV
Активиране на EON TV
Настройки на CA модул
Настройки на CA модул
Застраховки
Застраховки
Планове за хора с увреждания
Планове за хора с увреждания
Достъпност на сайта
Достъпност на сайта
Електронни фактури
Електронни фактури
EUR BGN
Валутен курс: 1 EUR = 1.95583 лв.
© VIVACOM 2026
Google app
App store
Huawei store
Facebook
TikTok
YouTube
Instagram
Linkedin
United group
Отворена джаджа за чат
1...
|
Firefox
|
Смартфони от Vivacom – открийте най-новите модели Смартфони от Vivacom – открийте най-новите модели — Personal...
|
www.vivacom.bg/devices/smartphones#&brands=Sam www.vivacom.bg/devices/smartphones#&brands=Samsung&page=2...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
VIVACOM
VIVACOM
Смартфони от Vivacom – открийте най-новите модели
Смартфони от Vivacom – открийте най-новите модели
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
Премини към основното съдържание
Активиране на достъпност за хора със слабо зрение
Отворете менюто за достъпност
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Преподпиши своята мобилна услуга онлайн
Преподпиши своята мобилна услуга онлайн
Виж предложенията за преподписване за твоите услуги
Виж офертите - отвори в нов раздел
Виж офертите
Виж офертите
Next slide
филтри
Сортирай по
избери опция
избери опция
УСТРОЙСТВА (29)
УСТРОЙСТВА (29)
Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE Front Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE 128GB 14.32€ | 28.01лв. /мес. Previous price was €15.99 | 31.27лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 259.99€ | 508.50лв.
Samsung
SAMSUNG GALAXY A37 5G 128GB
SAMSUNG GALAXY A37 5G 128GB
AWESOME WHITE 128GB
14.32€
|
28.01лв.
/мес.
|
31.27лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
259.99€ | 508.50лв.
Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE Front Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE 128GB 15.32€ | 29.96лв. /мес. Previous price was €16.99 | 33.23лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 289.99€ | 567.17лв.
Samsung
SAMSUNG GALAXY A57 5G 128GB
SAMSUNG GALAXY A57 5G 128GB
AWESOME ICEBLUE 128GB
15.32€
|
29.96лв.
/мес.
|
33.23лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
289.99€ | 567.17лв.
Избор на цвят AWESOME GRAY Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY Front Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY 256GB 17.32€ | 33.87лв. /мес. Previous price was €18.99 | 37.14лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 349.99€ | 684.52лв.
Samsung
SAMSUNG GALAXY A57 5G 256GB
SAMSUNG GALAXY A57 5G 256GB
AWESOME GRAY 256GB
17.32€
|
33.87лв.
/мес.
|
37.14лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
349.99€ | 684.52лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26 ULTRA 256GB BLACK Front Samsung SAMSUNG GALAXY S26 ULTRA 256GB BLACK 256GB 55.99€ | 109.51лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1149.99€ | 2249.18лв.
Samsung
SAMSUNG GALAXY S26 ULTRA 256GB
SAMSUNG GALAXY S26 ULTRA 256GB
BLACK 256GB
55.99€
|
109.51лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1149.99€ | 2249.18лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26 ULTRA 512GB BLACK Front Samsung SAMSUNG GALAXY S26 ULTRA 512GB BLACK 512GB 65.99€ | 129.07лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1349.99€ | 2640.35лв.
Samsung
SAMSUNG GALAXY S26 ULTRA 512GB
SAMSUNG GALAXY S26 ULTRA 512GB
BLACK 512GB
65.99€
|
129.07лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1349.99€ | 2640.35лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26 ULTRA 1TB BLACK Front Samsung SAMSUNG GALAXY S26 ULTRA 1TB BLACK 1TB 80.99€ | 158.40лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1649.99€ | 3227.10лв.
Samsung
SAMSUNG GALAXY S26 ULTRA 1TB
SAMSUNG GALAXY S26 ULTRA 1TB
BLACK 1TB
80.99€
|
158.40лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1649.99€ | 3227.10лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26+ 256GB BLACK Front Samsung SAMSUNG GALAXY S26+ 256GB BLACK 256GB 46.99€ | 91.90лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 949.99€ | 1858.02лв.
Samsung
SAMSUNG GALAXY S26+ 256GB
SAMSUNG GALAXY S26+ 256GB
BLACK 256GB
46.99€
|
91.90лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
949.99€ | 1858.02лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26+ 512GB BLACK Front Samsung SAMSUNG GALAXY S26+ 512GB BLACK 512GB 55.99€ | 109.51лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1149.99€ | 2249.18лв.
Samsung
SAMSUNG GALAXY S26+ 512GB
SAMSUNG GALAXY S26+ 512GB
BLACK 512GB
55.99€
|
109.51лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1149.99€ | 2249.18лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26 256GB BLACK Front Samsung SAMSUNG GALAXY S26 256GB BLACK 256GB 38.99€ | 76.26лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 799.99€ | 1564.64лв.
Samsung
SAMSUNG GALAXY S26 256GB
SAMSUNG GALAXY S26 256GB
BLACK 256GB
38.99€
|
76.26лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
799.99€ | 1564.64лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY S26 512GB BLACK Front Samsung SAMSUNG GALAXY S26 512GB BLACK 512GB 43.99€ | 86.04лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 899.99€ | 1760.23лв.
Samsung
SAMSUNG GALAXY S26 512GB
SAMSUNG GALAXY S26 512GB
BLACK 512GB
43.99€
|
86.04лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
899.99€ | 1760.23лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY A26 5G 128GB BLACK Front Samsung SAMSUNG GALAXY A26 5G 128GB BLACK 128GB 5.99€ | 11.72лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 119.99€ | 234.68лв.
Samsung
SAMSUNG GALAXY A26 5G 128GB
SAMSUNG GALAXY A26 5G 128GB
BLACK 128GB
5.99€
|
11.72лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
119.99€ | 234.68лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY Z FLIP7 FE 256GB BLACK Front Samsung SAMSUNG GALAXY Z FLIP7 FE 256GB BLACK 256GB 26.99€ | 52.79лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 549.99€ | 1075.69лв.
Samsung
SAMSUNG GALAXY Z FLIP7 FE 256GB
SAMSUNG GALAXY Z FLIP7 FE 256GB
BLACK 256GB
26.99€
|
52.79лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
549.99€ | 1075.69лв.
Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Samsung SAMSUNG GALAXY A36 5G 128GB AWESOME WHITE Front Samsung SAMSUNG GALAXY A36 5G 128GB AWESOME WHITE 128GB 7.99€ | 15.63лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 139.99€ | 273.80лв.
Samsung
SAMSUNG GALAXY A36 5G 128GB
SAMSUNG GALAXY A36 5G 128GB
AWESOME WHITE 128GB
7.99€
|
15.63лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
139.99€ | 273.80лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY A17 5G 128GB BLACK Front Samsung SAMSUNG GALAXY A17 5G 128GB BLACK 128GB 2.99€ | 5.85лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 59.99€ | 117.33лв.
Samsung
SAMSUNG GALAXY A17 5G 128GB
SAMSUNG GALAXY A17 5G 128GB
BLACK 128GB
2.99€
|
5.85лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
59.99€ | 117.33лв.
Избор на цвят JETBLACK Samsung SAMSUNG GALAXY S25 FE 5G 128GB JETBLACK Front Samsung SAMSUNG GALAXY S25 FE 5G 128GB JETBLACK 128GB 19.99€ | 39.10лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 399.99€ | 782.31лв.
Samsung
SAMSUNG GALAXY S25 FE 5G 128GB
SAMSUNG GALAXY S25 FE 5G 128GB
JETBLACK 128GB
19.99€
|
39.10лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
399.99€ | 782.31лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW 512GB 41.67€ | 81.50лв. /мес. 46.99€ | 91.90лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 999.99€ | 1955.81лв.
Samsung
SAMSUNG GALAXY Z FLIP7 512GB
SAMSUNG GALAXY Z FLIP7 512GB
BLUE SHADOW 512GB
41.67€
|
81.50лв.
/мес.
46.99€
|
91.90лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
999.99€ | 1955.81лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW 256GB 60.42€ | 118.17лв. /мес. 70.99€ | 138.84лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1449.99€ | 2835.93лв.
Samsung
SAMSUNG GALAXY Z FOLD7 256GB
SAMSUNG GALAXY Z FOLD7 256GB
SILVER SHADOW 256GB
60.42€
|
118.17лв.
/мес.
70.99€
|
138.84лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1449.99€ | 2835.93лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW 512GB 66.67€ | 130.40лв. /мес. 77.99€ | 152.54лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1599.99€ | 3129.31лв.
Samsung
SAMSUNG GALAXY Z FOLD7 512GB
SAMSUNG GALAXY Z FOLD7 512GB
SILVER SHADOW 512GB
66.67€
|
130.40лв.
/мес.
77.99€
|
152.54лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1599.99€ | 3129.31лв.
Избор на цвят TITANIUM ICYBLUE Избор на цвят TITANIUM ICYBLUE Samsung SAMSUNG GALAXY S25 EDGE 5G 256GB TITANIUM ICYBLUE Front Samsung SAMSUNG GALAXY S25 EDGE 5G 256GB TITANIUM ICYBLUE 256GB 34.99€ | 68.43лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 709.99€ | 1388.62лв.
Samsung
SAMSUNG GALAXY S25 EDGE 5G 256GB
SAMSUNG GALAXY S25 EDGE 5G 256GB
TITANIUM ICYBLUE 256GB
34.99€
|
68.43лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
709.99€ | 1388.62лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW 1TB 78.33€ | 153.20лв. /мес. 92.99€ | 181.87лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1879.99€ | 3676.94лв.
Samsung
SAMSUNG GALAXY Z FOLD7 1TB
SAMSUNG GALAXY Z FOLD7 1TB
BLUE SHADOW 1TB
78.33€
|
153.20лв.
/мес.
92.99€
|
181.87лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1879.99€ | 3676.94лв.
В комплект с протектор Избор на цвят AWESOME GRAPHITE Избор на цвят AWESOME GRAPHITE Избор на цвят AWESOME GRAPHITE Избор на цвят AWESOME GRAPHITE Samsung Samsung Galaxy A56 5G 128GB + Протектор AWESOME GRAPHITE Front Samsung Samsung Galaxy A56 5G 128GB + Протектор AWESOME GRAPHITE 128GB 12.26€ | 23.98лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 245.41€ | 479.98лв.
В комплект с протектор
Samsung
Samsung Galaxy A56 5G 128GB + Протектор
Samsung Galaxy A56 5G 128GB + Протектор
AWESOME GRAPHITE 128GB
12.26€
|
23.98лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
245.41€ | 479.98лв.
Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Samsung SAMSUNG GALAXY S25 ULTRA 512GB TITANIUM BLACK Front Samsung SAMSUNG GALAXY S25 ULTRA 512GB TITANIUM BLACK 512GB 42.99€ | 84.08лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 869.99€ | 1701.55лв.
Samsung
SAMSUNG GALAXY S25 ULTRA 512GB
SAMSUNG GALAXY S25 ULTRA 512GB
TITANIUM BLACK 512GB
42.99€
|
84.08лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
869.99€ | 1701.55лв.
Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Избор на цвят TITANIUM BLACK Samsung SAMSUNG GALAXY S25 ULTRA 1TB TITANIUM BLACK Front Samsung SAMSUNG GALAXY S25 ULTRA 1TB TITANIUM BLACK 1TB 55.99€ | 109.51лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1139.99€ | 2229.63лв.
Samsung
SAMSUNG GALAXY S25 ULTRA 1TB
SAMSUNG GALAXY S25 ULTRA 1TB
TITANIUM BLACK 1TB
55.99€
|
109.51лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1139.99€ | 2229.63лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK Front Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK 128GB 20.83€ | 40.74лв. /мес. 23.99€ | 46.92лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 499.99€ | 977.90лв.
Samsung
SAMSUNG GALAXY Z FLIP7 FE 128GB
SAMSUNG GALAXY Z FLIP7 FE 128GB
BLACK 128GB
20.83€
|
40.74лв.
/мес.
23.99€
|
46.92лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
499.99€ | 977.90лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW 256GB 37.50€ | 73.34лв. /мес. 42.99€ | 84.08лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 899.99€ | 1760.23лв.
Samsung
SAMSUNG GALAXY Z FLIP7 256GB
SAMSUNG GALAXY Z FLIP7 256GB
BLUE SHADOW 256GB
37.50€
|
73.34лв.
/мес.
42.99€
|
84.08лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
899.99€ | 1760.23лв.
Избор на цвят BLACK Samsung SAMSUNG GALAXY XCOVER 7 PRO 128GB BLACK Front Samsung SAMSUNG GALAXY XCOVER 7 PRO 128GB BLACK 128GB 12.99€ | 25.41лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 259.99€ | 508.50лв.
Samsung
SAMSUNG GALAXY XCOVER 7 PRO 128GB
SAMSUNG GALAXY XCOVER 7 PRO 128GB
BLACK 128GB
12.99€
|
25.41лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
259.99€ | 508.50лв.
Избор на цвят LIGHT GREEN Samsung SAMSUNG GALAXY A16 4G 128GB LIGHT GREEN Front Samsung SAMSUNG GALAXY A16 4G 128GB LIGHT GREEN 128GB 1.99€ | 3.89лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 29.99€ | 58.66лв.
Samsung
SAMSUNG GALAXY A16 4G 128GB
SAMSUNG GALAXY A16 4G 128GB
LIGHT GREEN 128GB
1.99€
|
3.89лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
29.99€ | 58.66лв.
Избор на цвят MINT Избор на цвят MINT Избор на цвят MINT Избор на цвят MINT Избор на цвят MINT Samsung SAMSUNG GALAXY S25 256GB MINT Front Samsung SAMSUNG GALAXY S25 256GB MINT 256GB 26.99€ | 52.79лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 539.99€ | 1056.13лв.
Samsung
SAMSUNG GALAXY S25 256GB
SAMSUNG GALAXY S25 256GB
MINT 256GB
26.99€
|
52.79лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
539.99€ | 1056.13лв.
Избор на цвят MINT Избор на цвят MINT Избор на цвят MINT Избор на цвят MINT Samsung SAMSUNG GALAXY S25 512GB MINT Front Samsung SAMSUNG GALAXY S25 512GB MINT 512GB 32.99€ | 64.52лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 669.99€ | 1310.39лв.
Samsung
SAMSUNG GALAXY S25 512GB
SAMSUNG GALAXY S25 512GB
MINT 512GB
32.99€
|
64.52лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
669.99€ | 1310.39лв.
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия...
|
Firefox
|
Смартфони от Vivacom – открийте най-новите модели Смартфони от Vivacom – открийте най-новите модели — Personal...
|
www.vivacom.bg/devices/smartphones#&brands=Sam www.vivacom.bg/devices/smartphones#&brands=Samsung&page=2...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Вземи смартфони с до 120 € отстъпка с Unlimited план
Вземи смартфони с до 120 € отстъпка с Unlimited план
Възползвай се от специалните майски промоции и вземи избрани смартфони с до 120 € отстъпка с Unlimited план.
Официални правила
Официални правила
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия
Общи условия
Общи условия
Мобилно покритие
Мобилно покритие
Лични данни
Лични данни
Правила за ползване
Правила за ползване
Роуминг
Роуминг
Политика за бисквитките
Политика за бисквитките
Полезни връзки
Полезни връзки
Устройство в сервиз
Устройство в сервиз
Спешни номера
Спешни номера
Активиране на EON TV
Активиране на EON TV
Настройки на CA модул
Настройки на CA модул
Застраховки
Застраховки
Планове за хора с увреждания
Планове за хора с увреждания
Достъпност на сайта
Достъпност на сайта
Електронни фактури
Електронни фактури
EUR BGN
Валутен курс: 1 EUR = 1.95583 лв.
© VIVACOM 2026
Google app
App store
Huawei store
Facebook
TikTok
YouTube
Instagram
Linkedin
United group
Read cdn.userway.org...
|
Firefox
|
Смартфони с Unlimited план до 120 € отстъпка | Viv Смартфони с Unlimited план до 120 € отстъпка | Vivacom — Personal...
|
www.vivacom.bg/devices/device-of-the-month?utm_sou www.vivacom.bg/devices/device-of-the-month?utm_source=self-care&utm_medium=hp&utm_campaign=pom-26...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Вземи смартфони с до 120 € отстъпка с Unlimited план
Вземи смартфони с до 120 € отстъпка с Unlimited план
Възползвай се от специалните майски промоции и вземи избрани смартфони с до 120 € отстъпка с Unlimited план.
Официални правила
Официални правила
Преподпиши своята мобилна услуга онлайн
Преподпиши своята мобилна услуга онлайн
Виж предложенията за преподписване за твоите услуги
Виж офертите Виж офертите
Виж офертите
Виж офертите
филтри
Сортирай по
избери опция
избери опция
УСТРОЙСТВА (0)
УСТРОЙСТВА (0)
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия
Общи условия
Общи условия
Мобилно покритие
Мобилно покритие
Лични данни
Лични данни
Правила за ползване
Правила за ползване
Роуминг
Роуминг
Политика за бисквитките
Политика за бисквитките
Полезни връзки
Полезни връзки
Устройство в сервиз
Устройство в сервиз
Спешни номера
Спешни номера
Активиране на EON TV
Активиране на EON TV
Настройки на CA модул
Настройки на CA модул
Застраховки
Застраховки
Планове за хора с увреждания
Планове за хора с увреждания
Достъпност на сайта
Достъпност на сайта
Електронни фактури
Електронни фактури
EUR BGN
Валутен курс: 1 EUR = 1.95583 лв.
© VIVACOM 2026
Google app
App store
Huawei store
Facebook
TikTok
YouTube
Instagram
Linkedin
United group
Отворена джаджа за чат
1
Read app2.salesmanago.pl...
|
Firefox
|
Смартфони с Unlimited план до 120 € отстъпка | Viv Смартфони с Unlimited план до 120 € отстъпка | Vivacom — Personal...
|
www.vivacom.bg/devices/device-of-the-month?utm_sou www.vivacom.bg/devices/device-of-the-month?utm_source=self-care&utm_medium=hp&utm_campaign=pom-26...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
Премини към основното съдържание
Активиране на достъпност за хора със слабо зрение
Отворете менюто за достъпност
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Вземи смартфони с до 120 € отстъпка с Unlimited план
Вземи смартфони с до 120 € отстъпка с Unlimited план
Възползвай се от специалните майски промоции и вземи избрани смартфони с до 120 € отстъпка с Unlimited план.
Официални правила
Официални правила
Преподпиши своята мобилна услуга онлайн
Преподпиши своята мобилна услуга онлайн
Виж предложенията за преподписване за твоите услуги
Виж офертите Виж офертите
Виж офертите
Виж офертите
филтри
Сортирай по
избери опция
избери опция
УСТРОЙСТВА (9)
УСТРОЙСТВА (9)
Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE Front Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE 128GB 14.32€ | 28.01лв. /мес. 15.99€ | 31.27лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 259.99€ | 508.50лв.
Samsung
SAMSUNG GALAXY A37 5G 128GB
SAMSUNG GALAXY A37 5G 128GB
AWESOME WHITE 128GB
14.32€
|
28.01лв.
/мес.
15.99€
|
31.27лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
259.99€ | 508.50лв.
Избор на цвят AWESOME GRAY Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY Front Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY 256GB 17.32€ | 33.87лв. /мес. 18.99€ | 37.14лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 349.99€ | 684.52лв.
Samsung
SAMSUNG GALAXY A57 5G 256GB
SAMSUNG GALAXY A57 5G 256GB
AWESOME GRAY 256GB
17.32€
|
33.87лв.
/мес.
18.99€
|
37.14лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
349.99€ | 684.52лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK Front Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK 128GB 20.83€ | 40.74лв. /мес. 23.99€ | 46.92лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 499.99€ | 977.90лв.
Samsung
SAMSUNG GALAXY Z FLIP7 FE 128GB
SAMSUNG GALAXY Z FLIP7 FE 128GB
BLACK 128GB
20.83€
|
40.74лв.
/мес.
23.99€
|
46.92лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
499.99€ | 977.90лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW 512GB 41.67€ | 81.50лв. /мес. 46.99€ | 91.90лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 999.99€ | 1955.81лв.
Samsung
SAMSUNG GALAXY Z FLIP7 512GB
SAMSUNG GALAXY Z FLIP7 512GB
BLUE SHADOW 512GB
41.67€
|
81.50лв.
/мес.
46.99€
|
91.90лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
999.99€ | 1955.81лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW 256GB 60.42€ | 118.17лв. /мес. 70.99€ | 138.84лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1449.99€ | 2835.93лв.
Samsung
SAMSUNG GALAXY Z FOLD7 256GB
SAMSUNG GALAXY Z FOLD7 256GB
SILVER SHADOW 256GB
60.42€
|
118.17лв.
/мес.
70.99€
|
138.84лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1449.99€ | 2835.93лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW 512GB 66.67€ | 130.40лв. /мес. 77.99€ | 152.54лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1599.99€ | 3129.31лв.
Samsung
SAMSUNG GALAXY Z FOLD7 512GB
SAMSUNG GALAXY Z FOLD7 512GB
SILVER SHADOW 512GB
66.67€
|
130.40лв.
/мес.
77.99€
|
152.54лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1599.99€ | 3129.31лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW 1TB 78.33€ | 153.20лв. /мес. 92.99€ | 181.87лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1879.99€ | 3676.94лв.
Samsung
SAMSUNG GALAXY Z FOLD7 1TB
SAMSUNG GALAXY Z FOLD7 1TB
BLUE SHADOW 1TB
78.33€
|
153.20лв.
/мес.
92.99€
|
181.87лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1879.99€ | 3676.94лв.
Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE Front Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE 128GB 15.32€ | 29.96лв. /мес. 16.99€ | 33.23лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 289.99€ | 567.17лв.
Samsung
SAMSUNG GALAXY A57 5G 128GB
SAMSUNG GALAXY A57 5G 128GB
AWESOME ICEBLUE 128GB
15.32€
|
29.96лв.
/мес.
16.99€
|
33.23лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
289.99€ | 567.17лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW 256GB 37.50€ | 73.34лв. /мес. 42.99€ | 84.08лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 899.99€ | 1760.23лв.
Samsung
SAMSUNG GALAXY Z FLIP7 256GB
SAMSUNG GALAXY Z FLIP7 256GB
BLUE SHADOW 256GB
37.50€
|
73.34лв.
/мес.
42.99€
|
84.08лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
899.99€ | 1760.23лв.
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия
Общи условия
Общи условия
Мобилно покритие
Мобилно покритие
Лични данни
Лични данни
Правила за ползване
Правила за ползване
Роуминг
Роуминг
Политика за бисквитките
Политика за бисквитките
Полезни връзки
Полезни връзки
Устройство в сервиз
Устройство в сервиз
Спешни номера
Спешни номера
Активиране на EON TV
Активиране на EON TV
Настройки на CA модул
Настройки на CA модул
Застраховки
Застраховки
Планове за хора с увреждания
Планове за хора с увреждания
Достъпност на сайта
Достъпност на сайта
Електронни фактури
Електронни фактури
EUR BGN
Валутен курс: 1 EUR = 1.95583 лв.
© VIVACOM 2026
Google app
App store
Huawei store
Facebook
TikTok
YouTube
Instagram
Linkedin
United group
Отворена джаджа за чат
1
Open CMP widget...
|
Firefox
|
Смартфони с Unlimited план до 120 € отстъпка | Viv Смартфони с Unlimited план до 120 € отстъпка | Vivacom — Personal...
|
www.vivacom.bg/devices/device-of-the-month?utm_sou www.vivacom.bg/devices/device-of-the-month?utm_source=self-care&utm_medium=hp&utm_campaign=pom-26#&brands=Samsung...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
Премини към основното съдържание
Активиране на достъпност за хора със слабо зрение
Отворете менюто за достъпност
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Вземи смартфони с до 120 € отстъпка с Unlimited план
Вземи смартфони с до 120 € отстъпка с Unlimited план
Възползвай се от специалните майски промоции и вземи избрани смартфони с до 120 € отстъпка с Unlimited план.
Официални правила
Официални правила
Преподпиши своята мобилна услуга онлайн
Преподпиши своята мобилна услуга онлайн
Виж предложенията за преподписване за твоите услуги
Виж офертите Виж офертите
Виж офертите
Виж офертите
филтри
Сортирай по
избери опция
избери опция
УСТРОЙСТВА (9)
УСТРОЙСТВА (9)
Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE Front Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE 128GB 14.32€ | 28.01лв. /мес. 15.99€ | 31.27лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 259.99€ | 508.50лв.
Samsung
SAMSUNG GALAXY A37 5G 128GB
SAMSUNG GALAXY A37 5G 128GB
AWESOME WHITE 128GB
14.32€
|
28.01лв.
/мес.
15.99€
|
31.27лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
259.99€ | 508.50лв.
Избор на цвят AWESOME GRAY Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY Front Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY 256GB 17.32€ | 33.87лв. /мес. 18.99€ | 37.14лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 349.99€ | 684.52лв.
Samsung
SAMSUNG GALAXY A57 5G 256GB
SAMSUNG GALAXY A57 5G 256GB
AWESOME GRAY 256GB
17.32€
|
33.87лв.
/мес.
18.99€
|
37.14лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
349.99€ | 684.52лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK Front Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK 128GB 20.83€ | 40.74лв. /мес. 23.99€ | 46.92лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 499.99€ | 977.90лв.
Samsung
SAMSUNG GALAXY Z FLIP7 FE 128GB
SAMSUNG GALAXY Z FLIP7 FE 128GB
BLACK 128GB
20.83€
|
40.74лв.
/мес.
23.99€
|
46.92лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
499.99€ | 977.90лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW 512GB 41.67€ | 81.50лв. /мес. 46.99€ | 91.90лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 999.99€ | 1955.81лв.
Samsung
SAMSUNG GALAXY Z FLIP7 512GB
SAMSUNG GALAXY Z FLIP7 512GB
BLUE SHADOW 512GB
41.67€
|
81.50лв.
/мес.
46.99€
|
91.90лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
999.99€ | 1955.81лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW 256GB 60.42€ | 118.17лв. /мес. 70.99€ | 138.84лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1449.99€ | 2835.93лв.
Samsung
SAMSUNG GALAXY Z FOLD7 256GB
SAMSUNG GALAXY Z FOLD7 256GB
SILVER SHADOW 256GB
60.42€
|
118.17лв.
/мес.
70.99€
|
138.84лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1449.99€ | 2835.93лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW 512GB 66.67€ | 130.40лв. /мес. 77.99€ | 152.54лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1599.99€ | 3129.31лв.
Samsung
SAMSUNG GALAXY Z FOLD7 512GB
SAMSUNG GALAXY Z FOLD7 512GB
SILVER SHADOW 512GB
66.67€
|
130.40лв.
/мес.
77.99€
|
152.54лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1599.99€ | 3129.31лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW 1TB 78.33€ | 153.20лв. /мес. 92.99€ | 181.87лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1879.99€ | 3676.94лв.
Samsung
SAMSUNG GALAXY Z FOLD7 1TB
SAMSUNG GALAXY Z FOLD7 1TB
BLUE SHADOW 1TB
78.33€
|
153.20лв.
/мес.
92.99€
|
181.87лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1879.99€ | 3676.94лв.
Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE Front Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE 128GB 15.32€ | 29.96лв. /мес. 16.99€ | 33.23лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 289.99€ | 567.17лв.
Samsung
SAMSUNG GALAXY A57 5G 128GB
SAMSUNG GALAXY A57 5G 128GB
AWESOME ICEBLUE 128GB
15.32€
|
29.96лв.
/мес.
16.99€
|
33.23лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
289.99€ | 567.17лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW 256GB 37.50€ | 73.34лв. /мес. 42.99€ | 84.08лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 899.99€ | 1760.23лв.
Samsung
SAMSUNG GALAXY Z FLIP7 256GB
SAMSUNG GALAXY Z FLIP7 256GB
BLUE SHADOW 256GB
37.50€
|
73.34лв.
/мес.
42.99€
|
84.08лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
899.99€ | 1760.23лв.
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия
Общи условия
Общи условия
Мобилно покритие
Мобилно покритие
Лични данни
Лични данни
Правила за ползване
Правила за ползване
Роуминг
Роуминг
Политика за бисквитките
Политика за бисквитките
Полезни връзки
Полезни връзки
Устройство в сервиз
Устройство в сервиз
Спешни номера
Спешни номера
Активиране на EON TV
Активиране на EON TV
Настройки на CA модул
Настройки на CA модул
Застраховки
Застраховки
Планове за хора с увреждания
Планове за хора с увреждания
Достъпност на сайта
Достъпност на сайта
Електронни фактури
Електронни фактури
EUR BGN
Валутен курс: 1 EUR = 1.95583 лв.
© VIVACOM 2026
Google app
App store
Huawei store
Facebook
TikTok
YouTube
Instagram
Linkedin
United group
Отворена джаджа за чат
1
Open CMP widget...
|
Firefox
|
Смартфони с Unlimited план до 120 € отстъпка | Viv Смартфони с Unlimited план до 120 € отстъпка | Vivacom — Personal...
|
www.vivacom.bg/devices/device-of-the-month?utm_sou www.vivacom.bg/devices/device-of-the-month?utm_source=self-care&utm_medium=hp&utm_campaign=pom-26#&brands=Samsung...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
Transferring data from www.vivacom.bg…...
|
Firefox
|
Смартфони с Unlimited план до 120 € отстъпка | Viv Смартфони с Unlimited план до 120 € отстъпка | Vivacom — Personal...
|
www.vivacom.bg/devices/device-of-the-month?utm_sou www.vivacom.bg/devices/device-of-the-month?utm_source=self-care&utm_medium=hp&utm_campaign=pom-26...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Вземи смартфони с до 120 € отстъпка с Unlimited план
Вземи смартфони с до 120 € отстъпка с Unlimited план
Възползвай се от специалните майски промоции и вземи избрани смартфони с до 120 € отстъпка с Unlimited план.
Официални правила
Официални правила
Преподпиши своята мобилна услуга онлайн
Преподпиши своята мобилна услуга онлайн
Виж предложенията за преподписване за твоите услуги
Виж офертите Виж офертите
Виж офертите
Виж офертите
филтри
Сортирай по
избери опция
избери опция
УСТРОЙСТВА (0)
УСТРОЙСТВА (0)
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия
Общи условия
Общи условия
Мобилно покритие
Мобилно покритие
Лични данни
Лични данни
Правила за ползване
Правила за ползване
Роуминг
Роуминг
Политика за бисквитките
Политика за бисквитките
Полезни връзки
Полезни връзки
Устройство в сервиз
Устройство в сервиз
Спешни номера
Спешни номера
Активиране на EON TV
Активиране на EON TV
Настройки на CA модул
Настройки на CA модул
Застраховки
Застраховки
Планове за хора с увреждания
Планове за хора с увреждания
Достъпност на сайта
Достъпност на сайта
Електронни фактури
Електронни фактури
EUR BGN
Валутен курс: 1 EUR = 1.95583 лв.
© VIVACOM 2026
Google app
App store
Huawei store
Facebook
TikTok
YouTube
Instagram
Linkedin
United group
Open chat widget
Read app2.salesmanago.pl...
|
Firefox
|
Смартфони с Unlimited план до 120 € отстъпка | Viv Смартфони с Unlimited план до 120 € отстъпка | Vivacom — Personal...
|
www.vivacom.bg/devices/device-of-the-month?utm_sou www.vivacom.bg/devices/device-of-the-month?utm_source=self-care&utm_medium=hp&utm_campaign=pom-26...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
Премини към основното съдържание
Активиране на достъпност за хора със слабо зрение
Отворете менюто за достъпност
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Вземи смартфони с до 120 € отстъпка с Unlimited план
Вземи смартфони с до 120 € отстъпка с Unlimited план
Възползвай се от специалните майски промоции и вземи избрани смартфони с до 120 € отстъпка с Unlimited план.
Официални правила
Официални правила
Преподпиши своята мобилна услуга онлайн
Преподпиши своята мобилна услуга онлайн
Виж предложенията за преподписване за твоите услуги
Виж офертите Виж офертите
Виж офертите
Виж офертите
филтри
Сортирай по
избери опция
избери опция
УСТРОЙСТВА (15)
УСТРОЙСТВА (15)
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Xiaomi XIAOMI REDMI NOTE 15 4G 128GB BLACK Front Xiaomi XIAOMI REDMI NOTE 15 4G 128GB BLACK 128GB 4.32€ | 8.45лв. /мес. 5.99€ | 11.72лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 69.99€ | 136.89лв.
Xiaomi
XIAOMI REDMI NOTE 15 4G 128GB
XIAOMI REDMI NOTE 15 4G 128GB
BLACK 128GB
4.32€
|
8.45лв.
/мес.
5.99€
|
11.72лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
69.99€ | 136.89лв.
Избор на цвят BLACK Избор на цвят BLACK Избор на цвят BLACK Xiaomi XIAOMI REDMI NOTE 15 PRO 5G 256GB BLACK Front Xiaomi XIAOMI REDMI NOTE 15 PRO 5G 256GB BLACK 256GB 10.32€ | 20.18лв. /мес. 11.99€ | 23.45лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 189.99€ | 371.59лв.
Xiaomi
XIAOMI REDMI NOTE 15 PRO 5G 256GB
XIAOMI REDMI NOTE 15 PRO 5G 256GB
BLACK 256GB
10.32€
|
20.18лв.
/мес.
11.99€
|
23.45лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
189.99€ | 371.59лв.
Избор на цвят BLACK Избор на цвят BLACK Xiaomi XIAOMI REDMI NOTE 15 PRO+ 5G 512GB BLACK Front Xiaomi XIAOMI REDMI NOTE 15 PRO+ 5G 512GB BLACK 512GB 12.32€ | 24.10лв. /мес. 13.99€ | 27.36лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 229.99€ | 449.82лв.
Xiaomi
XIAOMI REDMI NOTE 15 PRO+ 5G 512GB
XIAOMI REDMI NOTE 15 PRO+ 5G 512GB
BLACK 512GB
12.32€
|
24.10лв.
/мес.
13.99€
|
27.36лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
229.99€ | 449.82лв.
Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE Front Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE 128GB 14.32€ | 28.01лв. /мес. 15.99€ | 31.27лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 259.99€ | 508.50лв.
Samsung
SAMSUNG GALAXY A37 5G 128GB
SAMSUNG GALAXY A37 5G 128GB
AWESOME WHITE 128GB
14.32€
|
28.01лв.
/мес.
15.99€
|
31.27лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
259.99€ | 508.50лв.
Избор на цвят AWESOME GRAY Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY Front Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY 256GB 17.32€ | 33.87лв. /мес. 18.99€ | 37.14лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 349.99€ | 684.52лв.
Samsung
SAMSUNG GALAXY A57 5G 256GB
SAMSUNG GALAXY A57 5G 256GB
AWESOME GRAY 256GB
17.32€
|
33.87лв.
/мес.
18.99€
|
37.14лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
349.99€ | 684.52лв.
Избор на цвят GLAZED BLACK Избор на цвят GLAZED BLACK Избор на цвят GLAZED BLACK Huawei HUAWEI PURA 80 PRO 512GB GLAZED BLACK Front Huawei HUAWEI PURA 80 PRO 512GB GLAZED BLACK 512GB 30.99€ | 60.61лв. /мес. 38.99€ | 76.26лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 599.99€ | 1173.48лв.
Huawei
HUAWEI PURA 80 PRO 512GB
HUAWEI PURA 80 PRO 512GB
GLAZED BLACK 512GB
30.99€
|
60.61лв.
/мес.
38.99€
|
76.26лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
599.99€ | 1173.48лв.
Избор на цвят PRESTIGE GOLD Huawei HUAWEI PURA 80 ULTRA 512GB PRESTIGE GOLD Front Huawei HUAWEI PURA 80 ULTRA 512GB PRESTIGE GOLD 512GB 50.99€ | 99.73лв. /мес. 58.99€ | 115.37лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 999.99€ | 1955.81лв.
Huawei
HUAWEI PURA 80 ULTRA 512GB
HUAWEI PURA 80 ULTRA 512GB
PRESTIGE GOLD 512GB
50.99€
|
99.73лв.
/мес.
58.99€
|
115.37лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
999.99€ | 1955.81лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK Front Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK 128GB 20.83€ | 40.74лв. /мес. 23.99€ | 46.92лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 499.99€ | 977.90лв.
Samsung
SAMSUNG GALAXY Z FLIP7 FE 128GB
SAMSUNG GALAXY Z FLIP7 FE 128GB
BLACK 128GB
20.83€
|
40.74лв.
/мес.
23.99€
|
46.92лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
499.99€ | 977.90лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW 512GB 41.67€ | 81.50лв. /мес. 46.99€ | 91.90лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 999.99€ | 1955.81лв.
Samsung
SAMSUNG GALAXY Z FLIP7 512GB
SAMSUNG GALAXY Z FLIP7 512GB
BLUE SHADOW 512GB
41.67€
|
81.50лв.
/мес.
46.99€
|
91.90лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
999.99€ | 1955.81лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW 256GB 60.42€ | 118.17лв. /мес. 70.99€ | 138.84лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1449.99€ | 2835.93лв.
Samsung
SAMSUNG GALAXY Z FOLD7 256GB
SAMSUNG GALAXY Z FOLD7 256GB
SILVER SHADOW 256GB
60.42€
|
118.17лв.
/мес.
70.99€
|
138.84лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1449.99€ | 2835.93лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW 512GB 66.67€ | 130.40лв. /мес. 77.99€ | 152.54лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1599.99€ | 3129.31лв.
Samsung
SAMSUNG GALAXY Z FOLD7 512GB
SAMSUNG GALAXY Z FOLD7 512GB
SILVER SHADOW 512GB
66.67€
|
130.40лв.
/мес.
77.99€
|
152.54лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1599.99€ | 3129.31лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW 1TB 78.33€ | 153.20лв. /мес. 92.99€ | 181.87лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1879.99€ | 3676.94лв.
Samsung
SAMSUNG GALAXY Z FOLD7 1TB
SAMSUNG GALAXY Z FOLD7 1TB
BLUE SHADOW 1TB
78.33€
|
153.20лв.
/мес.
92.99€
|
181.87лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1879.99€ | 3676.94лв.
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия
Общи условия
Общи условия
Мобилно покритие
Мобилно покритие
Лични данни
Лични данни
Правила за ползване
Правила за ползване
Роуминг
Роуминг
Политика за бисквитките
Политика за бисквитките
Полезни връзки
Полезни връзки
Устройство в сервиз
Устройство в сервиз
Спешни номера
Спешни номера
Активиране на EON TV
Активиране на EON TV
Настройки на CA модул
Настройки на CA модул
Застраховки
Застраховки
Планове за хора с увреждания
Планове за хора с увреждания
Достъпност на сайта
Достъпност на сайта
Електронни фактури
Електронни фактури
EUR BGN
Валутен курс: 1 EUR = 1.95583 лв.
© VIVACOM 2026
Google app
App store
Huawei store
Facebook
TikTok
YouTube
Instagram
Linkedin
United group
Отворена джаджа за чат
1
Open CMP widget...
|
Firefox
|
Смартфони с Unlimited план до 120 € отстъпка | Viv Смартфони с Unlimited план до 120 € отстъпка | Vivacom — Personal...
|
www.vivacom.bg/devices/device-of-the-month?utm_sou www.vivacom.bg/devices/device-of-the-month?utm_source=self-care&utm_medium=hp&utm_campaign=pom-26...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
Премини към основното съдържание
Активиране на достъпност за хора със слабо зрение
Отворете менюто за достъпност
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Вземи смартфони с до 120 € отстъпка с Unlimited план
Вземи смартфони с до 120 € отстъпка с Unlimited план
Възползвай се от специалните майски промоции и вземи избрани смартфони с до 120 € отстъпка с Unlimited план.
Официални правила
Официални правила
Преподпиши своята мобилна услуга онлайн
Преподпиши своята мобилна услуга онлайн
Виж предложенията за преподписване за твоите услуги
Виж офертите Виж офертите
Виж офертите
Виж офертите
филтри
Сортирай по
избери опция
избери опция
УСТРОЙСТВА (9)
УСТРОЙСТВА (9)
Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE Front Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE 128GB 14.32€ | 28.01лв. /мес. 15.99€ | 31.27лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 259.99€ | 508.50лв.
Samsung
SAMSUNG GALAXY A37 5G 128GB
SAMSUNG GALAXY A37 5G 128GB
AWESOME WHITE 128GB
14.32€
|
28.01лв.
/мес.
15.99€
|
31.27лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
259.99€ | 508.50лв.
Избор на цвят AWESOME GRAY Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY Front Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY 256GB 17.32€ | 33.87лв. /мес. 18.99€ | 37.14лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 349.99€ | 684.52лв.
Samsung
SAMSUNG GALAXY A57 5G 256GB
SAMSUNG GALAXY A57 5G 256GB
AWESOME GRAY 256GB
17.32€
|
33.87лв.
/мес.
18.99€
|
37.14лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
349.99€ | 684.52лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK Front Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK 128GB 20.83€ | 40.74лв. /мес. 23.99€ | 46.92лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 499.99€ | 977.90лв.
Samsung
SAMSUNG GALAXY Z FLIP7 FE 128GB
SAMSUNG GALAXY Z FLIP7 FE 128GB
BLACK 128GB
20.83€
|
40.74лв.
/мес.
23.99€
|
46.92лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
499.99€ | 977.90лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW 512GB 41.67€ | 81.50лв. /мес. 46.99€ | 91.90лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 999.99€ | 1955.81лв.
Samsung
SAMSUNG GALAXY Z FLIP7 512GB
SAMSUNG GALAXY Z FLIP7 512GB
BLUE SHADOW 512GB
41.67€
|
81.50лв.
/мес.
46.99€
|
91.90лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
999.99€ | 1955.81лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW 256GB 60.42€ | 118.17лв. /мес. 70.99€ | 138.84лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1449.99€ | 2835.93лв.
Samsung
SAMSUNG GALAXY Z FOLD7 256GB
SAMSUNG GALAXY Z FOLD7 256GB
SILVER SHADOW 256GB
60.42€
|
118.17лв.
/мес.
70.99€
|
138.84лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1449.99€ | 2835.93лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW 512GB 66.67€ | 130.40лв. /мес. 77.99€ | 152.54лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1599.99€ | 3129.31лв.
Samsung
SAMSUNG GALAXY Z FOLD7 512GB
SAMSUNG GALAXY Z FOLD7 512GB
SILVER SHADOW 512GB
66.67€
|
130.40лв.
/мес.
77.99€
|
152.54лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1599.99€ | 3129.31лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW 1TB 78.33€ | 153.20лв. /мес. 92.99€ | 181.87лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1879.99€ | 3676.94лв.
Samsung
SAMSUNG GALAXY Z FOLD7 1TB
SAMSUNG GALAXY Z FOLD7 1TB
BLUE SHADOW 1TB
78.33€
|
153.20лв.
/мес.
92.99€
|
181.87лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1879.99€ | 3676.94лв.
Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE Front Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE 128GB 15.32€ | 29.96лв. /мес. 16.99€ | 33.23лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 289.99€ | 567.17лв.
Samsung
SAMSUNG GALAXY A57 5G 128GB
SAMSUNG GALAXY A57 5G 128GB
AWESOME ICEBLUE 128GB
15.32€
|
29.96лв.
/мес.
16.99€
|
33.23лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
289.99€ | 567.17лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW 256GB 37.50€ | 73.34лв. /мес. 42.99€ | 84.08лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 899.99€ | 1760.23лв.
Samsung
SAMSUNG GALAXY Z FLIP7 256GB
SAMSUNG GALAXY Z FLIP7 256GB
BLUE SHADOW 256GB
37.50€
|
73.34лв.
/мес.
42.99€
|
84.08лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
899.99€ | 1760.23лв.
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия
Общи условия
Общи условия
Мобилно покритие
Мобилно покритие
Лични данни
Лични данни
Правила за ползване
Правила за ползване
Роуминг
Роуминг
Политика за бисквитките
Политика за бисквитките
Полезни връзки
Полезни връзки
Устройство в сервиз
Устройство в сервиз
Спешни номера
Спешни номера
Активиране на EON TV
Активиране на EON TV
Настройки на CA модул
Настройки на CA модул
Застраховки
Застраховки
Планове за хора с увреждания
Планове за хора с увреждания
Достъпност на сайта
Достъпност на сайта
Електронни фактури
Електронни фактури
EUR BGN
Валутен курс: 1 EUR = 1.95583 лв.
© VIVACOM 2026
Google app
App store
Huawei store
Facebook
TikTok
YouTube
Instagram
Linkedin
United group
Отворена джаджа за чат
1
Open CMP widget...
|
Firefox
|
Смартфони с Unlimited план до 120 € отстъпка | Viv Смартфони с Unlimited план до 120 € отстъпка | Vivacom — Personal...
|
www.vivacom.bg/devices/device-of-the-month?utm_sou www.vivacom.bg/devices/device-of-the-month?utm_source=self-care&utm_medium=hp&utm_campaign=pom-26#&brands=Samsung...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
Премини към основното съдържание
Активиране на достъпност за хора със слабо зрение
Отворете менюто за достъпност
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Вземи смартфони с до 120 € отстъпка с Unlimited план
Вземи смартфони с до 120 € отстъпка с Unlimited план
Възползвай се от специалните майски промоции и вземи избрани смартфони с до 120 € отстъпка с Unlimited план.
Официални правила - отвори в нов раздел
Официални правила
Преподпиши своята мобилна услуга онлайн
Преподпиши своята мобилна услуга онлайн
Виж предложенията за преподписване за твоите услуги
Виж офертите - отвори в нов раздел
Виж офертите
Виж офертите
филтри
Сортирай по
избери опция
избери опция
УСТРОЙСТВА (9)
УСТРОЙСТВА (9)
Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE Front Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE 128GB 14.32€ | 28.01лв. /мес. 15.99€ | 31.27лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 259.99€ | 508.50лв.
Samsung
SAMSUNG GALAXY A37 5G 128GB
SAMSUNG GALAXY A37 5G 128GB
AWESOME WHITE 128GB
14.32€
|
28.01лв.
/мес.
15.99€
|
31.27лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
259.99€ | 508.50лв.
Избор на цвят AWESOME GRAY Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY Front Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY 256GB 17.32€ | 33.87лв. /мес. 18.99€ | 37.14лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 349.99€ | 684.52лв.
Samsung
SAMSUNG GALAXY A57 5G 256GB
SAMSUNG GALAXY A57 5G 256GB
AWESOME GRAY 256GB
17.32€
|
33.87лв.
/мес.
18.99€
|
37.14лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
349.99€ | 684.52лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK Front Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK 128GB 20.83€ | 40.74лв. /мес. 23.99€ | 46.92лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 499.99€ | 977.90лв.
Samsung
SAMSUNG GALAXY Z FLIP7 FE 128GB
SAMSUNG GALAXY Z FLIP7 FE 128GB
BLACK 128GB
20.83€
|
40.74лв.
/мес.
23.99€
|
46.92лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
499.99€ | 977.90лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW 512GB 41.67€ | 81.50лв. /мес. 46.99€ | 91.90лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 999.99€ | 1955.81лв.
Samsung
SAMSUNG GALAXY Z FLIP7 512GB
SAMSUNG GALAXY Z FLIP7 512GB
BLUE SHADOW 512GB
41.67€
|
81.50лв.
/мес.
46.99€
|
91.90лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
999.99€ | 1955.81лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW 256GB 60.42€ | 118.17лв. /мес. 70.99€ | 138.84лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1449.99€ | 2835.93лв.
Samsung
SAMSUNG GALAXY Z FOLD7 256GB
SAMSUNG GALAXY Z FOLD7 256GB
SILVER SHADOW 256GB
60.42€
|
118.17лв.
/мес.
70.99€
|
138.84лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1449.99€ | 2835.93лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW 512GB 66.67€ | 130.40лв. /мес. 77.99€ | 152.54лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1599.99€ | 3129.31лв.
Samsung
SAMSUNG GALAXY Z FOLD7 512GB
SAMSUNG GALAXY Z FOLD7 512GB
SILVER SHADOW 512GB
66.67€
|
130.40лв.
/мес.
77.99€
|
152.54лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1599.99€ | 3129.31лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW 1TB 78.33€ | 153.20лв. /мес. 92.99€ | 181.87лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1879.99€ | 3676.94лв.
Samsung
SAMSUNG GALAXY Z FOLD7 1TB
SAMSUNG GALAXY Z FOLD7 1TB
BLUE SHADOW 1TB
78.33€
|
153.20лв.
/мес.
92.99€
|
181.87лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1879.99€ | 3676.94лв.
Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE Front Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE 128GB 15.32€ | 29.96лв. /мес. 16.99€ | 33.23лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 289.99€ | 567.17лв.
Samsung
SAMSUNG GALAXY A57 5G 128GB
SAMSUNG GALAXY A57 5G 128GB
AWESOME ICEBLUE 128GB
15.32€
|
29.96лв.
/мес.
16.99€
|
33.23лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
289.99€ | 567.17лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW 256GB 37.50€ | 73.34лв. /мес. 42.99€ | 84.08лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 899.99€ | 1760.23лв.
Samsung
SAMSUNG GALAXY Z FLIP7 256GB
SAMSUNG GALAXY Z FLIP7 256GB
BLUE SHADOW 256GB
37.50€
|
73.34лв.
/мес.
42.99€
|
84.08лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
899.99€ | 1760.23лв.
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия
Общи условия
Общи условия
Мобилно покритие
Мобилно покритие
Лични данни
Лични данни
Правила за ползване
Правила за ползване
Роуминг
Роуминг
Политика за бисквитките
Политика за бисквитките
Полезни връзки
Полезни връзки
Устройство в сервиз
Устройство в сервиз
Спешни номера
Спешни номера
Активиране на EON TV
Активиране на EON TV
Настройки на CA модул
Настройки на CA модул
Застраховки
Застраховки
Планове за хора с увреждания
Планове за хора с увреждания
Достъпност на сайта
Достъпност на сайта
Електронни фактури
Електронни фактури
EUR BGN
Валутен курс: 1 EUR = 1.95583 лв.
© VIVACOM 2026
Google app
App store
Huawei store
Facebook
TikTok
YouTube
Instagram
Linkedin
United group
Отворена джаджа за чат
1
Open CMP widget
www.vivacom.bg/devices/samsung-galaxy-z-flip7-fe-128gb/000000000050013816_4...
|
Firefox
|
Смартфони с Unlimited план до 120 € отстъпка | Viv Смартфони с Unlimited план до 120 € отстъпка | Vivacom — Personal...
|
www.vivacom.bg/devices/device-of-the-month?utm_sou www.vivacom.bg/devices/device-of-the-month?utm_source=self-care&utm_medium=hp&utm_campaign=pom-26#&brands=Samsung...
|
|
Pull requests · screenpipe/screenpipe · GitHub
Pul Pull requests · screenpipe/screenpipe · GitHub
Pull requests · screenpipe/screenpipe · GitHub
DNS / Nameservers | Hostinger
DNS / Nameservers | Hostinger
Nginx Proxy Manager
Nginx Proxy Manager
Screenpipe — Archive
Screenpipe — Archive
SQLite Web: archive.db
SQLite Web: archive.db
SQLite Web: db.sqlite
SQLite Web: db.sqlite
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
screenpipe/.claude/skills at main · screenpipe/screenpipe · GitHub
DXP4800PLUS-B5F8
DXP4800PLUS-B5F8
AFFiNE - All In One KnowledgeOS
AFFiNE - All In One KnowledgeOS
All docs · AFFiNE
All docs · AFFiNE
Payments Logger
Payments Logger
Inbox - [EMAIL] - Gmail
Inbox - [EMAIL] - Gmail
(25) Quora
(25) Quora
Location Logger
Location Logger
Finance Hub
Finance Hub
Finance Hub
Finance Hub
Select: payments - db - Adminer
Select: payments - db - Adminer
Електронно банкиране ДСК Директ от Банка ДСК
Електронно банкиране ДСК Директ от Банка ДСК
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
Stop Losing Notes: Pick A Cross-Device App That Syncs | AFFiNE
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
VIVACOM
VIVACOM
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Смартфони с Unlimited план до 120 € отстъпка | Vivacom
Close tab
New Tab
Customize sidebar
Open Google Gemini (⌃X)
Open history (⇧⌘H)
Open bookmarks (⌘B)
Bitwarden
Премини към основното съдържание
Активиране на достъпност за хора със слабо зрение
Отворете менюто за достъпност
ЧАСТНИ КЛИЕНТИ
ЧАСТНИ КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
БИЗНЕС КЛИЕНТИ
Cart
Мобилни услуги
Устройства
EON
Интернет
Други услуги
Помощ
МАГАЗИНИ
МАГАЗИНИ
ГЛЕДАЙ EON
ГЛЕДАЙ EON
КОНТАКТИ
КОНТАКТИ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
ОБЩИ УСЛОВИЯ
КАРТИ НА ПОКРИТИЕТО
КАРТИ НА ПОКРИТИЕТО
Accessibility widget
Vivacom Logo
Вземи смартфони с до 120 € отстъпка с Unlimited план
Вземи смартфони с до 120 € отстъпка с Unlimited план
Възползвай се от специалните майски промоции и вземи избрани смартфони с до 120 € отстъпка с Unlimited план.
Официални правила - отвори в нов раздел
Официални правила
Преподпиши своята мобилна услуга онлайн
Преподпиши своята мобилна услуга онлайн
Виж предложенията за преподписване за твоите услуги
Виж офертите - отвори в нов раздел
Виж офертите
Виж офертите
филтри
Сортирай по
избери опция
избери опция
УСТРОЙСТВА (9)
УСТРОЙСТВА (9)
Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Избор на цвят AWESOME WHITE Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE Front Samsung SAMSUNG GALAXY A37 5G 128GB AWESOME WHITE 128GB 14.32€ | 28.01лв. /мес. Previous price was €15.99 | 31.27лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 259.99€ | 508.50лв.
Samsung
SAMSUNG GALAXY A37 5G 128GB
SAMSUNG GALAXY A37 5G 128GB
AWESOME WHITE 128GB
14.32€
|
28.01лв.
/мес.
|
31.27лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
259.99€ | 508.50лв.
Избор на цвят AWESOME GRAY Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY Front Samsung SAMSUNG GALAXY A57 5G 256GB AWESOME GRAY 256GB 17.32€ | 33.87лв. /мес. Previous price was €18.99 | 37.14лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 349.99€ | 684.52лв.
Samsung
SAMSUNG GALAXY A57 5G 256GB
SAMSUNG GALAXY A57 5G 256GB
AWESOME GRAY 256GB
17.32€
|
33.87лв.
/мес.
|
37.14лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
349.99€ | 684.52лв.
Избор на цвят BLACK Избор на цвят BLACK Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK Front Samsung SAMSUNG GALAXY Z FLIP7 FE 128GB BLACK 128GB 20.83€ | 40.74лв. /мес. Previous price was €23.99 | 46.92лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 499.99€ | 977.90лв.
Samsung
SAMSUNG GALAXY Z FLIP7 FE 128GB
SAMSUNG GALAXY Z FLIP7 FE 128GB
BLACK 128GB
20.83€
|
40.74лв.
/мес.
|
46.92лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
499.99€ | 977.90лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 512GB BLUE SHADOW 512GB 41.67€ | 81.50лв. /мес. Previous price was €46.99 | 91.90лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 999.99€ | 1955.81лв.
Samsung
SAMSUNG GALAXY Z FLIP7 512GB
SAMSUNG GALAXY Z FLIP7 512GB
BLUE SHADOW 512GB
41.67€
|
81.50лв.
/мес.
|
91.90лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
999.99€ | 1955.81лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 256GB SILVER SHADOW 256GB 60.42€ | 118.17лв. /мес. Previous price was €70.99 | 138.84лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1449.99€ | 2835.93лв.
Samsung
SAMSUNG GALAXY Z FOLD7 256GB
SAMSUNG GALAXY Z FOLD7 256GB
SILVER SHADOW 256GB
60.42€
|
118.17лв.
/мес.
|
138.84лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1449.99€ | 2835.93лв.
Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Избор на цвят SILVER SHADOW Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 512GB SILVER SHADOW 512GB 66.67€ | 130.40лв. /мес. Previous price was €77.99 | 152.54лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1599.99€ | 3129.31лв.
Samsung
SAMSUNG GALAXY Z FOLD7 512GB
SAMSUNG GALAXY Z FOLD7 512GB
SILVER SHADOW 512GB
66.67€
|
130.40лв.
/мес.
|
152.54лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1599.99€ | 3129.31лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FOLD7 1TB BLUE SHADOW 1TB 78.33€ | 153.20лв. /мес. Previous price was €92.99 | 181.87лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 1879.99€ | 3676.94лв.
Samsung
SAMSUNG GALAXY Z FOLD7 1TB
SAMSUNG GALAXY Z FOLD7 1TB
BLUE SHADOW 1TB
78.33€
|
153.20лв.
/мес.
|
181.87лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
1879.99€ | 3676.94лв.
Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Избор на цвят AWESOME ICEBLUE Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE Front Samsung SAMSUNG GALAXY A57 5G 128GB AWESOME ICEBLUE 128GB 15.32€ | 29.96лв. /мес. Previous price was €16.99 | 33.23лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 289.99€ | 567.17лв.
Samsung
SAMSUNG GALAXY A57 5G 128GB
SAMSUNG GALAXY A57 5G 128GB
AWESOME ICEBLUE 128GB
15.32€
|
29.96лв.
/мес.
|
33.23лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
289.99€ | 567.17лв.
Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Избор на цвят BLUE SHADOW Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW Front Samsung SAMSUNG GALAXY Z FLIP7 256GB BLUE SHADOW 256GB 37.50€ | 73.34лв. /мес. 42.99€ | 84.08лв. /мес. 24-мес. вноски с Unlimited MAX В брой: 899.99€ | 1760.23лв.
Samsung
SAMSUNG GALAXY Z FLIP7 256GB
SAMSUNG GALAXY Z FLIP7 256GB
BLUE SHADOW 256GB
37.50€
|
73.34лв.
/мес.
42.99€
|
84.08лв.
/мес.
24-мес. вноски с Unlimited MAX
В брой:
899.99€ | 1760.23лв.
Close
филтри
филтри
Цена
Памет
Изчисти
Изчисти
Приложи
Приложи
Компанията
Компанията
За нас
За нас
Етика и съответствие
Етика и съответствие
Марката Vivacom
Марката Vivacom
Мениджмънт
Мениджмънт
Социална отговорност
Социална отговорност
Новини
Новини
Кариери
Кариери
Доставчици
Доставчици
Доклад за устойчиво развитие
Доклад за устойчиво развитие
Частни клиенти
Частни клиенти
Мобилни планове
Мобилни планове
Мобилен интернет
Мобилен интернет
Устройства
Устройства
Интернет пакети
Интернет пакети
Програма Лоялен клиент
Програма Лоялен клиент
Правила и условия
Правила и условия
Общи условия
Общи условия
Мобилно покритие
Мобилно покритие
Лични данни
Лични данни
Правила за ползване
Правила за ползване
Роуминг
Роуминг
Политика за бисквитките
Политика за бисквитките
Полезни връзки
Полезни връзки
Устройство в сервиз
Устройство в сервиз
Спешни номера
Спешни номера
Активиране на EON TV
Активиране на EON TV
Настройки на CA модул
Настройки на CA модул
Застраховки
Застраховки
Планове за хора с увреждания
Планове за хора с увреждания
Достъпност на сайта
Достъпност на сайта
Електронни фактури
Електронни фактури
EUR BGN
Валутен курс: 1 EUR = 1.95583 лв.
© VIVACOM 2026
Google app
App store
Huawei store
Facebook
TikTok
YouTube
Instagram
Linkedin
United group
Отворена джаджа за чат
1
Open CMP widget
www.vivacom.bg/devices/samsung-galaxy-a37-5g-128gb/000000000050014210_20315...
|
Firefox
|
Смартфони с Unlimited план до 120 € отстъпка | Viv Смартфони с Unlimited план до 120 € отстъпка | Vivacom — Personal...
|
www.vivacom.bg/devices/device-of-the-month?utm_sou www.vivacom.bg/devices/device-of-the-month?utm_source=self-care&utm_medium=hp&utm_campaign=pom-26#&brands=Samsung...
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 22 pending changes
22
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
CheckAndRetryRemoteMatch.php
CreateFollowupActivity.php
CreateNotes.php
MatchActivitiesToNewOpportunity.php
MatchActivityCrmData.php
M
NoteObject.php
SaveActivity.php
SaveTranscription.php
SetupLayout.php
SyncActivity.php
SyncFieldMetadata.php
SyncHubspotObjects.php
SyncLeads.php
SyncObjects.php
SyncOpportunitiesJob.php
SyncOpportunity.php
SyncProfileMetadata.php
SyncTeamFieldsJob.php
SyncTeamMetadata.php
UpdateOpportunitySpecifications.php
UpdateStage.php
DealRisks
Mailbox
MeetingBot
Middleware
HandleHubspotRateLimit.php
M
RateLimited.php
Streaming
Team
Telephony
User
BaseProcessingJob.php
DummyJob.php
ImportRecallAIRecordingsJob.php
ImportRemoteTrackJob.php
Job.php
JobDispatcher.php
JobDispatcherInterface.php
PurgeSoftDeletedOpportunityJob.php
SqsVisibilityControl.php
Listeners
Mail
Models
Activity
Ai
AskAnything
Calendar
Connection
Crm
Jobs
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
✻ [Claude Code] Client.php (Client.php), Editor Group 1
Client.php, Editor Group 1
HubspotPaginationService.php, Editor Group 1
Review rate limit handli…, Editor Group 2
remote
app (Git) - JY-20725-handle-HS-search-rate-limit*+, Checkout Branch/Tag...
JY-20725-handle-HS-search-rate-limit*+
app (Git) - Publish Branch
Errors: 6, Warnings: 19, Infos: 4
6
19
4
Notifications
key, PHP extension: Premium features not active.
8.3, Language Level: 8.3
Sign In
Sign In
PHP
LF
UTF-8
Spaces: 4
Ln 45, Col 1
Diff editor
Clear
Review rate limit handling for HubSpot job queue
Session history
New session
Message actions
RateLimitException.php#9-9
RateLimitException.php#9-9
Reveiw the diff. Mostly
@app/Jobs/Crm/MatchActivityCrmData.php
,
@app/Exceptions/RateLimitException.php
,
@app/Jobs/Middleware/HandleHubspotRateLimit.php
,...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 22 pending changes
22
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
CheckAndRetryRemoteMatch.php
CreateFollowupActivity.php
CreateNotes.php
MatchActivitiesToNewOpportunity.php
MatchActivityCrmData.php
M
NoteObject.php
SaveActivity.php
SaveTranscription.php
SetupLayout.php...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 22 pending changes
22
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
EXPLORERAPPV appv Jobs# MatchActivitiesToNewOpportunity.ph## MatchActivityCrmData.phg## NoteObject.phpSaveActivitv.pho## SaveTranscription.php## SetupLayout.php## SyncActivitv.phe# SvncFieldMetadata.php# SvncHubspotObiects.phpSuncleads.ono# SvncObiects.ohd#SvncOpoortunities.lob.ohv# SvncOpnortunitv.php# SvncProfileMetadata.ohv## SyncTeamFieldsJob.php# SvncTeamMetadata.ohn# UpdateOpportunitySpecifications.php# UpdateStage.phpDealPicks> MeetingBotV MiddlowaroHandleHubspotRateLimit.phpRA RateLimited.php> Streamind) Toam> Telephony> UsenR# BaseProcessingJob.php## DummyJob.php# ImportRecallA|Recordinas.Job.ohd# ImportRemoteTrack.Job.php# .Job.ohp#.JobDispatcher.ohp#.JobDispatcherinterface.ohv# [EMAIL]# SasVisibilitvControl.ohr> MailActiviti#R MatchActivitvCrmData.php MRateLimitException.php MHandleHubspotRateLimit.php M> Hubcnot ) & Client nhn ) Ge Clien* [Claude Codel Client.php 9+ XClientphpuse hubspoc cllent erm propertles model propercy;use hubspoc cllenc erm propertles model Propercy;Hubspot\Discovery Discovery;19 use Jiminny\ Exceptions\ CrmException:useHubspot Discovery Discovery;use Jiminny Exceptions CrmException:20 use Jiminny Exceptions RateLimitException:21 use Jiminnv Excentions SocialAccountTokenInva UidExcention:use Jiminny\Jobs\Crm\Note0bject;use Jiminny Exceptions RateLimitException:use Jiminnv Excentions SocilalAccountTokenInvaUdExceotion:use liminnv lohs. erm. Notedhiect.use Jiminny\Models\Crm\Field;• Liminnvl Cervicec) Crml Racefl jent.ceptions Hubspotexception;use Jiminny\Services\Crm\Hubspot\Pagination\HubspotPaginationService;use autuminare support racades keats,use inrowable.* @phpstan-type CrmFieldOption array(id:string, label:string, value?:string)class Client extends BaseClient imolements HubsnotClientInterfacepublic const string MIN API VERSION = '2';public const string BASE URL = '[URL_WITH_CREDENTIALS] CrmFieldOption array{id:string, label:string, value?:string)class Client extends BaseClient imolements HubsnotClientInterfacepublic const string MIN API VERSION = '2';public const string BASE URL = '[URL_WITH_CREDENTIALS] = SpaginationService:Sthis->setBaseUrl(self::BASE URLYsthis-ssetVersion(self.:MTN APT VERSTON):* Execute a HubSpot API call with rate limit handling.* When a 429 is received, stores the absolute exoiry timestamo in Redis* that outlasts the release delav (retrvAfter + RATE LIMIT CACHE BUFFER* Subsequent callers comoute the remainina wait from that timestamo so4i* delaved lonaer than nececsarv. and the key stavs alive lona enouah toAparam callable(): T SapiCall The APT call to execute• athrows RateLimitExcention When rate limit is hit or cached rate Limii$this->setBaseUrl(self::BASE_URL):sthis-ssetVersion(self.:MTN APT VERSTON)•* Execute a HubSpot API call with rate limit handling.* When a 429 is received, stores the absolute expiry timestamp in Redis with* that outlasts the release delav (retrvAfter + RATE LIMIT CACHE BUFFER SECON* Subsequent callers comoute the remainina wait from that timestamo so thev1* delaved lonaer than nececsarv. and the kev stavs alive lona enouch to actua Atomniato Taparam callable(): T SapiCall The APT call to execute• T The result ofthe API call* @throws RateLimitException When rate limit is hit or cached rate limit is aTê JY-20725-h#Preparation for Refi... 48 m left100% L2• Mon 11 May 15:12:200 000•2 C3→ = Review rate limit handli..Review rate limit handling for HubSpot jo.Joonunders ancne sntnaoo mucho la window o wal. Le stus seelton neiscenano, uо oou va chAc ivivernpa aroos reda u ne sameu me makine00 0ou search requess. Wna wumnaopenrandwhen•e arana reaker win nerixeca ou chande recuces was ec mosoo cais sioni icantyeou aner nincein e c a each cache exols ais otaia1[ter or a Redis-backed semaphore that caps how many workers can call Hubspot per second globally, not per-job. That'sa separate, larger change. For the current scope, 120 minutes is a reasonable guard — just be aware it won't save 100k jobs in a true spikeok burt i don't understand the delay. Also lets say that there are 100 requests to hubspot first gets 429 and basically form taht point there is one second if it is secondly. In one second it iwll be free and requestswill pass. The cache should be set witt ttl form teh first iob that hit the limit. if it is constantlv updated wew ill never free it. Think again very carefully about the whole flow, do I need 10 minutes buffer. 1understand to have soem jitter in the HandleHubspotRateLimit but that is with delay not to flow it at the same time. Confirm my reasoning• Thouaht for 94s›• Your reasonina is correct. Let me soell out exactlv why. then confirm what to fix.The Problem With My BufferWith SETEX (which always overwrites TTL), when 100 jobs all get 429 in a burst, each one resets the TTL from scratch. With retryAfter=1 and RATE LIMIT CACHE BUFFER SECONDS=10 , job #100 (firing att=0.09s) writes SETEX kev TTL=11. and the kev doesn't expire until t=11.09, HubSpot accepts requests again at t=1 — but the cache blocks evervone for 10 extra seconds for no reasonWhat's Actually Needed#First writer wins —use Sa INX™ (setiinotexists) Joblii setsithelkey.oost:2=1100 also qet 429lbuatheir writes arel anoredlbecause thel key already exists. Thel mi Ws anchored to therins 429 notathe2. No buffer - TTL = retryAfter exactly. The jitter in HandleHubspotRateLimit (random int(0, 5) ) is already the spread mechanism. Released jobs fire at t = retryAfter + 0..5, naturallystaaaered. which is exactly what prevents thunderina herd on the second waveThe correct flow with secondly limit (retryAfter=1):t=0.00 Job #1 → 429 → SET NX (key, expiresAt=1, TTL=1) - released(delay=1+jitter)t=0.01 Job #2 → 429 → SET NX - FATLS (key exists. TTL untouched) - releasedt=6.09 Job #100 → 429 » SET NX » FATLS - releasedt=1.00 Key expires. HubSpot open.t=1.01 Job #2 (jitter=0) fires - succeeds /t=1-6lobs trickle in via jitter sonMake this edit to CLient.php?Clean, simple, correct. Now implementing:• Edit Client.php7Yes. alllow all edits this sessionMust exceed Handi eHuhsnotRa3 Ndstill find the cache kev alivenrivate conct int PATE I TMIT GTell Claude what to do insteadLn 45, Col 1 Spaces: 4 UTF-8 LF PHP 8 SignIn 8.3 P m...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 22 pending changes
22
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
CheckAndRetryRemoteMatch.php
CreateFollowupActivity.php
CreateNotes.php
MatchActivitiesToNewOpportunity.php
MatchActivityCrmData.php
M
NoteObject.php
SaveActivity.php
SaveTranscription.php
SetupLayout.php
SyncActivity.php
SyncFieldMetadata.php
SyncHubspotObjects.php
SyncLeads.php
SyncObjects.php
SyncOpportunitiesJob.php
SyncOpportunity.php
SyncProfileMetadata.php
SyncTeamFieldsJob.php
SyncTeamMetadata.php
UpdateOpportunitySpecifications.php
UpdateStage.php
DealRisks
Mailbox
MeetingBot
Middleware
HandleHubspotRateLimit.php
M
RateLimited.php
Streaming
Team
Telephony
User
BaseProcessingJob.php
DummyJob.php
ImportRecallAIRecordingsJob.php
ImportRemoteTrackJob.php
Job.php
JobDispatcher.php
JobDispatcherInterface.php
PurgeSoftDeletedOpportunityJob.php
SqsVisibilityControl.php
Listeners
Mail
Models
Activity
Ai
AskAnything
Calendar
Connection
Crm
Jobs
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
✻ [Claude Code] Client.php (Client.php), Editor Group 1
Client.php, Editor Group 1
HubspotPaginationService.php, Editor Group 1
...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 22 pending changes
22
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
CheckAndRetryRemoteMatch.php
CreateFollowupActivity.php
CreateNotes.php
MatchActivitiesToNewOpportunity.php
MatchActivityCrmData.php
M
NoteObject.php
SaveActivity.php
SaveTranscription.php
SetupLayout.php
SyncActivity.php
SyncFieldMetadata.php
SyncHubspotObjects.php
SyncLeads.php
SyncObjects.php
SyncOpportunitiesJob.php
SyncOpportunity.php
SyncProfileMetadata.php
SyncTeamFieldsJob.php
SyncTeamMetadata.php
UpdateOpportunitySpecifications.php
UpdateStage.php
DealRisks
Mailbox
MeetingBot
Middleware...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 22 pending changes
22
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
CheckAndRetryRemoteMatch.php
CreateFollowupActivity.php
CreateNotes.php
MatchActivitiesToNewOpportunity.php
MatchActivityCrmData.php
M
NoteObject.php
SaveActivity.php
SaveTranscription.php
SetupLayout.php
SyncActivity.php
SyncFieldMetadata.php
SyncHubspotObjects.php
SyncLeads.php
SyncObjects.php
SyncOpportunitiesJob.php
SyncOpportunity.php
SyncProfileMetadata.php
SyncTeamFieldsJob.php
SyncTeamMetadata.php
...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 12 pending changes
12
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 12 pending changes
12
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php
ResponseNormalize.php
Service.php
SyncFieldAction.php
SyncRelatedActivityManager.php
WebhookSyncBatchProcessor.php
IntegrationApp
Listeners
Metadata
Migration
Pipedrive
OpportunitySyncStrategy
ProspectSearchStrategy
ApiFields.php
OpportunitySyncStrategy
Hubspot
Crm
Services
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
Client.php, Editor Group 1
✻ [Claude Code] Client.php (Client.php), Editor Group 1
HubspotPaginationService.php, Editor Group 1
Review rate limit handli…, Editor Group 2
remote
app (Git) - JY-20725-handle-HS-search-rate-limit*, Checkout Branch/Tag...
JY-20725-handle-HS-search-rate-limit*
app (Git) - Synchronize Changes
Errors: 6, Warnings: 18, Infos: 4
6
18
4
Notifications
key, PHP extension: Premium features not active.
8.3, Language Level: 8.3
Sign In
Sign In
PHP
LF
UTF-8
Spaces: 4
Ln 120, Col 1
Diff editor
Clear
Review rate limit handling for HubSpot job queue
Session history
New session
Message actions
RateLimitException.php#9-9
RateLimitException.php#9-9
Reveiw the diff. Mostly
@app/Jobs/Crm/MatchActivityCrmData.php
,
@app/Exceptions/RateLimitException.php
,
@app/Jobs/Middleware/HandleHubspotRateLimit.php
,
@app/Services/Crm/Hubspot/Client.php
and
@app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php
. The issue is I am trying to make sure that instant spike of MatchActivityCrmData jobs willl handle 429 exceptions from hubspot. Revewi ti carefully and try to see potential issues and bottlenecks. Also RateLimitException was changerd from LogicException to RuntimeException. Is it ok. This exception is used by other paerts of code. Will ti break anything?
Thought for 5s
Thought for 5s
I'll review the implementation carefully. Let me first check how
RateLimitException
is used elsewhere and look at the test files and
PaginationState
.
Bash
Find all usages of RateLimitException outside the changed files
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/app --include="*.php" | grep -v "HandleHubspotRateLimit\|MatchActivityCrmData\|Client.php\|RateLimitException.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:17:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:68: RateLimitException |
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:15:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:58: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:19:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:76: RateLimitException |
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:50: * @throws RateLimitException When rate limit is hit
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php:195: // RateLimitException and other exceptions are re-thrown as-is
Read
PaginationState.php
PaginationState.php
Read
HandleHubspotRateLimitTest.php
HandleHubspotRateLimitTest.php
Bash
Check how RateLimitException is used in GenerateActionItemsJob
IN
grep -rn "RateLimitException\|LogicException\|RuntimeException" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -20
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
Bash
Find all catch blocks or instanceof checks for RateLimitException
IN
grep -rn "catch.*RateLimitException\|instanceof RateLimitException" /Users/lukas/jiminny/app/app --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:11: * Job middleware that catches RateLimitException from HubSpot API calls
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:24: } catch (RateLimitException $e) {
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:149: if (! $e instanceof RateLimitException) {
Bash
Find all test references to RateLimitException
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/tests --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:13:#[CoversClass(RateLimitException::class)]
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:14:class RateLimitExceptionTest extends TestCase
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:18: $exception = new RateLimitException();
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:28: $exception = new RateLimitException('Hubspot rate limit', 30, $previous);
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:52: $exception = new RateLimitException('test', $input);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:10:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:49: public function testPropagatesNonRateLimitExceptions(): void
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:103: throw new RateLimitException('rate limited', $retryAfter);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:150: throw new RateLimitException('rate limited', 1);
Bash
Check retry/failure handling in GenerateActionItemsJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -30
Copy code to clipboard
OUT
13:use Jiminny\Exceptions\RateLimitException;
51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
56: $this->release(30);
Bash
Check retry/failure handling in GenerateAiCallScoringJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php | head -30
Copy code to clipboard
OUT
17:use Jiminny\Exceptions\RateLimitException;
68: RateLimitException |
75: $this->release(30);
Bash
Check retry config in MatchActivityCrmData
IN
grep -n "retryAfter\|RETRY_WINDOW\|retryUntil\|maxTries" /Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php
Copy code to clipboard
OUT
34: private const int RETRY_WINDOW_MINUTES = 30;
45: public function retryUntil(): \DateTimeInterface
47: return now()->addMinutes(self::RETRY_WINDOW_MINUTES);
77: return self::RETRY_WINDOW_MINUTES * 60 + 60;
Bash
Check the cache key format
IN
grep -n "getRateLimitCacheKey\|hubspot:ratelimit" /Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Client.php
Copy code to clipboard
OUT
78: $cacheKey = $this->getRateLimitCacheKey();
110: private function getRateLimitCacheKey(): string
112: return sprintf('hubspot:ratelimit:portal:%d', $this->config->getId());
Bash
Find other jobs that might use the rate limit middleware
IN
grep -rn "class.*Middleware\|HandleHubspotRateLimit" /Users/lukas/jiminny/app/app/Jobs --include="*.php" | grep -v "HandleHubspotRateLimit.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:18:use Jiminny\Jobs\Middleware\HandleHubspotRateLimit;
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:42: return [new HandleHubspotRateLimit()];
Read
HubspotClientInterface.php
HubspotClientInterface.php
Thought for 73s
Thought for 73s
Now I have a complete picture. Here's my full analysis:
Review Summary
Review Summary
RuntimeException vs LogicException — Safe ✓
RuntimeException
vs
LogicException
— Safe ✓
The change is semantically correct and won't break anything.
LogicException
is for programmer errors (invalid arguments, contract violations). A rate limit from an external API is a runtime condition —
RuntimeException
is the right parent. All callers catch
RateLimitException
by name explicitly (union catches in
GenerateActionItemsJob
,
GenerateAiCallScoringJob
,
SummarizeTranscriptionJob
,
GenerateAiActivityTypeJob
) or check
instanceof RateLimitException
— none relies on the parent class type, so nothing breaks.
Issue 1 — Circuit breaker stores stale delay (most important bug)
Issue 1 — Circuit breaker stores stale delay (most important bug)
Client.php:94
Client.php:94
Copy code to clipboard
Redis::setex($cacheKey, $retryAfter, (string) $retryAfter);
The TTL is
$retryAfter
seconds, but the
stored value
is also the original
$retryAfter
. If a second job reads this cache 20 seconds later, it throws
RateLimitException(retryAfter=30)
and gets delayed 30 more seconds — even though only 10 remain. In a spike of 100 jobs, each subsequent job inflates its wait.
Fix:
store the absolute expiry timestamp, reconstruct the remaining delay when reading:
Copy code to clipboard
// on 429:
Redis::setex($cacheKey, $retryAfter, (string) (time() + $retryAfter));
// in the cached-read branch:
$remaining = max(1, (int) $cachedRetryAfter - time());
throw new RateLimitException('Hubspot rate limit (cached circuit-breaker)', $remaining);
Issue 2 — retryUntil() window may expire under sustained rate limiting
Issue 2 —
retryUntil()
window may expire under sustained rate limiting
MatchActivityCrmData.php:45-47
MatchActivityCrmData.php:45-47
retryUntil()
is calculated as
now() + 30 min
at
dispatch time
and stored in the job payload. With
MAX_RETRY_DELAY = 600s
, you only get ~3 rate-limit-triggered releases before the 30-minute window closes and the job is permanently failed. For a heavy 429 spike (daily limit, parsed as 600s), this can easily happen.
Consider increasing
RETRY_WINDOW_MINUTES
to 60 or more, or making it configurable. The
uniqueFor()
value should be updated to match.
Issue 3 — Only search() uses the circuit breaker, but other methods can still hit 429
Issue 3 — Only
search()
uses the circuit breaker, but other methods can still hit 429
Client.php:76-108
Client.php:76-108
executeRequest()
is only called from
search()
. Methods like
getOpportunityById()
,
batchReadObjects()
,
getContactByEmail()
bypass it entirely. If HubSpot's 429 is account-wide (not search-endpoint-specific), those methods will keep firing even while the circuit breaker is supposedly open. This is likely fine because the search endpoint has its own tighter quota (5 RPS), but it's worth being explicit in a comment.
Issue 4 — object $job type in middleware has no compile-time safety
Issue 4 —
object $job
type in middleware has no compile-time safety
HandleHubspotRateLimit.php:20
HandleHubspotRateLimit.php:20
Copy code to clipboard
public function handle(object $job, callable $next): void
Calling
$job->attempts()
and
$job->release()
on
object
will work at runtime since Laravel always passes jobs that use
InteractsWithQueue
, but PHPStan/psalm won't verify this and it could silently break in tests with bare mocks (as your test does use a
Job
mock that has
attempts()
— so the test is fine, but the real type contract is invisible). Minor, but worth tightening to
\Illuminate\Contracts\Queue\Job
.
What works well ✓
What works well ✓
RateLimitException
is caught by the middleware
before
it increments
maxExceptions
, so rate-limit releases don't consume the 3-exception budget for real failures.
The middleware's jitter (
random_int(0, 5)
) prevents thundering herd on release.
The log-sampling logic (
attempts <= 3 || attempts % 10 === 0
) keeps logs useful without flooding.
ShouldBeUnique
+
uniqueFor()
correctly prevents duplicate jobs queuing up during the rate-limit wait window.
RateLimitException
propagates cleanly through the DB transaction (rolled back), then through the job catch block (logged conditionally), then to the middleware which handles it.
The pagination service re-throws
RateLimitException
as-is and resets pagination state on the next job attempt — safe because offset restarts from 0.
Message actions
Expand on 1 and 2. Let's consider there are several jobs running from ten workers. They are out fired instantly, and therefore there is no cache when they look for cache, but once they receive 429, they store cache. Can there be some potential issues with that flow?
Thought for 91s
Thought for 91s
Let me trace the exact race conditions step by step.
Wave 1 — The Initial Burst (t=0)
Wave 1 — The Initial Burst (t=0)
All 10 workers execute simultaneously. Each does:
Copy code to clipboard
$cachedRetryAfter = Redis::get($cacheKey); // ALL TEN: null — cache miss
Cache doesn't exist yet, so all 10 proceed and hammer HubSpot's search endpoint simultaneously. HubSpot's search limit is 5 RPS per portal — 10 concurrent requests guarantees 429s. All 10 get 429, all 10 run:
Copy code to clipboard
Redis::setex($cacheKey, $retryAfter, (string) $retryAfter); // e.g. TTL=10, value="10"
throw new RateLimitException('Hubspot returned 429', $retryAfter, $e);
All 10 write the same key at nearly the same millisecond. Redis just accepts last-write-wins — no error, no coordination, 10 redundant writes. Then all 10 are caught by the middleware and released:
Copy code to clipboard
delay = max(1, min(10, 600)) + random_int(0, 5) → 10 to 15 seconds
So all 10 jobs land back in the queue, scheduled to fire between t=10 and t=15.
The Core Problem — TTL Expires Before Released Jobs Fire
The Core Problem — TTL Expires Before Released Jobs Fire
The Redis key was set with
TTL = retryAfter = 10
. The jobs were released with
delay = retryAfter + jitter = 10–15
.
Copy code to clipboard
Redis key expires: t = 10
Jobs start firing: t = 10 to t = 15
These are nearly the same window. The very first job that fires at t=10 may race against the TTL expiry. Jobs firing at t=11–15
will find an empty cache
because the key already expired. So the circuit breaker provides...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 12 pending changes
12
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php
ResponseNormalize.php
Service.php
SyncFieldAction.php
SyncRelatedActivityManager.php
WebhookSyncBatchProcessor.php
IntegrationApp
Listeners
Metadata
Migration
Pipedrive
OpportunitySyncStrategy
ProspectSearchStrategy
ApiFields.php
OpportunitySyncStrategy
Hubspot
Crm
Services
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
Client.php, Editor Group 1
✻ [Claude Code] Client.php (Client.php), Editor Group 1
HubspotPaginationService.php, Editor Group 1
Review rate limit handli…, Editor Group 2
remote
app (Git) - JY-20725-handle-HS-search-rate-limit*, Checkout Branch/Tag...
JY-20725-handle-HS-search-rate-limit*
app (Git) - Synchronize Changes
Errors: 6, Warnings: 18, Infos: 4
6
18
4
Notifications
key, PHP extension: Premium features not active.
8.3, Language Level: 8.3
Sign In
Sign In
PHP
LF
UTF-8
Spaces: 4
Ln 120, Col 1
Diff editor
Clear
Review rate limit handling for HubSpot job queue
Session history
New session
Message actions
RateLimitException.php#9-9
RateLimitException.php#9-9
Reveiw the diff. Mostly
@app/Jobs/Crm/MatchActivityCrmData.php
,
@app/Exceptions/RateLimitException.php
,
@app/Jobs/Middleware/HandleHubspotRateLimit.php
,
@app/Services/Crm/Hubspot/Client.php
and
@app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php
. The issue is I am trying to make sure that instant spike of MatchActivityCrmData jobs willl handle 429 exceptions from hubspot. Revewi ti carefully and try to see potential issues and bottlenecks. Also RateLimitException was changerd from LogicException to RuntimeException. Is it ok. This exception is used by other paerts of code. Will ti break anything?
Thought for 5s
Thought for 5s
I'll review the implementation carefully. Let me first check how
RateLimitException
is used elsewhere and look at the test files and
PaginationState
.
Bash
Find all usages of RateLimitException outside the changed files
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/app --include="*.php" | grep -v "HandleHubspotRateLimit\|MatchActivityCrmData\|Client.php\|RateLimitException.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:17:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:68: RateLimitException |
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:15:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:58: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:19:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:76: RateLimitException |
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:50: * @throws RateLimitException When rate limit is hit
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php:195: // RateLimitException and other exceptions are re-thrown as-is
Read
PaginationState.php
PaginationState.php
Read
HandleHubspotRateLimitTest.php
HandleHubspotRateLimitTest.php
Bash
Check how RateLimitException is used in GenerateActionItemsJob
IN
grep -rn "RateLimitException\|LogicException\|RuntimeException" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -20
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
Bash
Find all catch blocks or instanceof checks for RateLimitException...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 12 pending changes
12
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php
ResponseNormalize.php
Service.php
SyncFieldAction.php
SyncRelatedActivityManager.php
WebhookSyncBatchProcessor.php
IntegrationApp
Listeners
Metadata
Migration
Pipedrive
OpportunitySyncStrategy
ProspectSearchStrategy
ApiFields.php
OpportunitySyncStrategy
Hubspot
Crm
Services
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
Client.php, Editor Group 1
✻ [Claude Code] Client.php (Client.php), Editor Group 1
HubspotPaginationService.php, Editor Group 1
Review rate limit handli…, Editor Group 2
remote
app (Git) - JY-20725-handle-HS-search-rate-limit*, Checkout Branch/Tag...
JY-20725-handle-HS-search-rate-limit*
app (Git) - Synchronize Changes
Errors: 6, Warnings: 18, Infos: 4
6
18
4
Notifications
key, PHP extension: Premium features not active.
8.3, Language Level: 8.3
Sign In
Sign In
PHP
LF
UTF-8
Spaces: 4
Ln 120, Col 1
Diff editor
Clear
Review rate limit handling for HubSpot job queue
Session history
New session
Message actions
RateLimitException.php#9-9
RateLimitException.php#9-9
Reveiw the diff. Mostly
@app/Jobs/Crm/MatchActivityCrmData.php
,
@app/Exceptions/RateLimitException.php
,
@app/Jobs/Middleware/HandleHubspotRateLimit.php
,
@app/Services/Crm/Hubspot/Client.php
and
@app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php
. The issue is I am trying to make sure that instant spike of MatchActivityCrmData jobs willl handle 429 exceptions from hubspot. Revewi ti carefully and try to see potential issues and bottlenecks. Also RateLimitException was changerd from LogicException to RuntimeException. Is it ok. This exception is used by other paerts of code. Will ti break anything?
Thought for 5s
Thought for 5s
I'll review the implementation carefully. Let me first check how
RateLimitException
is used elsewhere and look at the test files and
PaginationState
.
Bash
Find all usages of RateLimitException outside the changed files
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/app --include="*.php" | grep -v "HandleHubspotRateLimit\|MatchActivityCrmData\|Client.php\|RateLimitException.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:17:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:68: RateLimitException |
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:15:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:58: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:19:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:76: RateLimitException |
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:50: * @throws RateLimitException When rate limit is hit
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php:195: // RateLimitException and other exceptions are re-thrown as-is
Read
PaginationState.php
PaginationState.php
Read
HandleHubspotRateLimitTest.php
HandleHubspotRateLimitTest.php
Bash
Check how RateLimitException is used in GenerateActionItemsJob
IN
grep -rn "RateLimitException\|LogicException\|RuntimeException" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -20
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
Bash
Find all catch blocks or instanceof checks for RateLimitException
IN
grep -rn "catch.*RateLimitException\|instanceof RateLimitException" /Users/lukas/jiminny/app/app --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:11: * Job middleware that catches RateLimitException from HubSpot API calls
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:24: } catch (RateLimitException $e) {
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:149: if (! $e instanceof RateLimitException) {
Bash
Find all test references to RateLimitException
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/tests --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:13:#[CoversClass(RateLimitException::class)]
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:14:class RateLimitExceptionTest extends TestCase
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:18: $exception = new RateLimitException();
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:28: $exception = new RateLimitException('Hubspot rate limit', 30, $previous);
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:52: $exception = new RateLimitException('test', $input);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:10:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:49: public function testPropagatesNonRateLimitExceptions(): void
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:103: throw new RateLimitException('rate limited', $retryAfter);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:150: throw new RateLimitException('rate limited', 1);
Bash
Check retry/failure handling in GenerateActionItemsJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -30
Copy code to clipboard
OUT
13:use Jiminny\Exceptions\RateLimitException;
51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
56: $this->release(30);
Bash
Check retry/failure handling in GenerateAiCallScoringJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php | head -30
Copy code to clipboard
OUT
17:use Jiminny\Exceptions\RateLimitException;
68: RateLimitException |
75: $this->release(30);
Bash
Check retry config in MatchActivityCrmData
IN
grep -n "retryAfter\|RETRY_WINDOW\|retryUntil\|maxTries" /Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php
Copy code to clipboard
OUT
34: private const int RETRY_WINDOW_MINUTES = 30;
45: public function retryUntil(): \DateTimeInterface
47: return now()->addMinutes(self::RETRY_WINDOW_MINUTES);
77: return self::RETRY_WINDOW_MINUTES * 60 + 60;
Bash
Check the cache key format
IN
grep -n "getRateLimitCacheKey\|hubspot:ratelimit" /Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Client.php
Copy code to clipboard
OUT
78: $cacheKey = $this->getRateLimitCacheKey();
110: private function getRateLimitCacheKey(): string
112: return sprintf('hubspot:ratelimit:portal:%d', $this->config->getId());
Bash
Find other jobs that might use the rate limit middleware
IN
grep -rn "class.*Middleware\|HandleHubspotRateLimit" /Users/lukas/jiminny/app/app/Jobs --include="*.php" | grep -v "HandleHubspotRateLimit.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:18:use Jiminny\Jobs\Middleware\HandleHubspotRateLimit;
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:42: return [new HandleHubspotRateLimit()];
Read
HubspotClientInterface.php
HubspotClientInterface.php
Thought for 73s
Thought for 73s
Now I have a complete picture. Here's my full analysis:
Review Summary
Review Summary
RuntimeException vs LogicException — Safe ✓
RuntimeException
vs
LogicException
— Safe ✓
The change is semantically correct and won't break anything.
LogicException
is for programmer errors (invalid arguments, contract violations). A rate limit from an external API is a runtime condition —
RuntimeException
is the right parent. All callers catch
RateLimitException
by name explicitly (union catches in...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 12 pending changes
12
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 12 pending changes
12
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 12 pending changes
12
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app — 9 ✻ [Claude Code] Client.php (Client.php) — app — 9 problems in this file...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app — 9 ✻ [Claude Code] Client.php (Client.php) — app — 9 problems in this file...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app — 9 ✻ [Claude Code] Client.php (Client.php) — app — 9 problems in this file...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9, M
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php
ResponseNormalize.php
Service.php
SyncFieldAction.php
SyncRelatedActivityManager.php
WebhookSyncBatchProcessor.php
IntegrationApp
Listeners
Metadata
Migration
Pipedrive
OpportunitySyncStrategy
ProspectSearchStrategy
ApiFields.php
OpportunitySyncStrategy
Hubspot
Crm
Services
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
Client.php, Editor Group 1
✻ [Claude Code] Client.php (Client.php), Editor Group 1
HubspotPaginationService.php, Editor Group 1
Review rate limit handli…, Editor Group 2
remote
app (Git) - JY-20725-handle-HS-search-rate-limit*, Checkout Branch/Tag...
JY-20725-handle-HS-search-rate-limit*
app (Git) - Synchronize Changes
Errors: 6, Warnings: 18, Infos: 4
6
18
4
Notifications
key, PHP extension: Premium features not active.
8.3, Language Level: 8.3
Sign In
Sign In
PHP
LF
UTF-8
Spaces: 4
Ln 308, Col 1
Diff editor
Clear
Review rate limit handling for HubSpot job queue
Session history
New session
Message actions
RateLimitException.php#9-9
RateLimitException.php#9-9
Reveiw the diff. Mostly
@app/Jobs/Crm/MatchActivityCrmData.php
,
@app/Exceptions/RateLimitException.php
,
@app/Jobs/Middleware/HandleHubspotRateLimit.php
,
@app/Services/Crm/Hubspot/Client.php
and
@app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php
. The issue is I am trying to make sure that instant spike of MatchActivityCrmData jobs willl handle 429 exceptions from hubspot. Revewi ti carefully and try to see potential issues and bottlenecks. Also RateLimitException was changerd from LogicException to RuntimeException. Is it ok. This exception is used by other paerts of code. Will ti break anything?
Thought for 5s
Thought for 5s
I'll review the implementation carefully. Let me first check how
RateLimitException
is used elsewhere and look at the test files and
PaginationState
.
Bash
Find all usages of RateLimitException outside the changed files
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/app --include="*.php" | grep -v "HandleHubspotRateLimit\|MatchActivityCrmData\|Client.php\|RateLimitException.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:17:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:68: RateLimitException |
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:15:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:58: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:19:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:76: RateLimitException |
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:50: * @throws RateLimitException When rate limit is hit
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php:195: // RateLimitException and other exceptions are re-thrown as-is
Read
PaginationState.php
PaginationState.php
Read
HandleHubspotRateLimitTest.php
HandleHubspotRateLimitTest.php
Bash
Check how RateLimitException is used in GenerateActionItemsJob
IN
grep -rn "RateLimitException\|LogicException\|RuntimeException" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -20
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
Bash
Find all catch blocks or instanceof checks for RateLimitException
IN
grep -rn "catch.*RateLimitException\|instanceof RateLimitException" /Users/lukas/jiminny/app/app --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:11: * Job middleware that catches RateLimitException from HubSpot API calls
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:24: } catch (RateLimitException $e) {
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:149: if (! $e instanceof RateLimitException) {
Bash
Find all test references to RateLimitException
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/tests --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:13:#[CoversClass(RateLimitException::class)]
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:14:class RateLimitExceptionTest extends TestCase
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:18: $exception = new RateLimitException();
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:28: $exception = new RateLimitException('Hubspot rate limit', 30, $previous);
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:52: $exception = new RateLimitException('test', $input);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:10:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:49: public function testPropagatesNonRateLimitExceptions(): void
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:103: throw new RateLimitException('rate limited', $retryAfter);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:150: throw new RateLimitException('rate limited', 1);
Bash
Check retry/failure handling in GenerateActionItemsJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -30
Copy code to clipboard
OUT
13:use Jiminny\Exceptions\RateLimitException;
51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
56: $this->release(30);
Bash
Check retry/failure handling in GenerateAiCallScoringJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php | head -30
Copy code to clipboard
OUT
17:use Jiminny\Exceptions\RateLimitException;
68: RateLimitException |
75: $this->release(30);
Bash
Check retry config in MatchActivityCrmData
IN
grep -n "retryAfter\|RETRY_WINDOW\|retryUntil\|maxTries" /Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php
Copy code to clipboard
OUT
34: private const int RETRY_WINDOW_MINUTES = 30;
45: public function retryUntil(): \DateTimeInterface
47: return now()->addMinutes(self::RETRY_WINDOW_MINUTES);
77: return self::RETRY_WINDOW_MINUTES * 60 + 60;
Bash
Check the cache key format
IN
grep -n "getRateLimitCacheKey\|hubspot:ratelimit" /Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Client.php
Copy code to clipboard
OUT
78: $cacheKey = $this->getRateLimitCacheKey();
110: private function getRateLimitCacheKey(): string
112: return sprintf('hubspot:ratelimit:portal:%d', $this->config->getId());
Bash
Find other jobs that might use the rate limit middleware
IN
grep -rn "class.*Middleware\|HandleHubspotRateLimit" /Users/lukas/jiminny/app/app/Jobs --include="*.php" | grep -v "HandleHubspotRateLimit.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:18:use Jiminny\Jobs\Middleware\HandleHubspotRateLimit;
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:42: return [new HandleHubspotRateLimit()];
Read
HubspotClientInterface.php
HubspotClientInterface.php
Thought for 73s
Thought for 73s
Now I have a complete picture. Here's my full analysis:
Review Summary
Review Summary
RuntimeException vs LogicException — Safe ✓
RuntimeException...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app — 9 ✻ [Claude Code] Client.php (Client.php) — app — 9 problems in this file...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9, M
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php
ResponseNormalize.php
Service.php
SyncFieldAction.php
SyncRelatedActivityManager.php
WebhookSyncBatchProcessor.php
IntegrationApp
Listeners
Metadata
Migration
Pipedrive
OpportunitySyncStrategy
ProspectSearchStrategy
ApiFields.php
OpportunitySyncStrategy
Hubspot
Crm
Services
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
Client.php, Editor Group 1
✻ [Claude Code] Client.php (Client.php), Editor Group 1
HubspotPaginationService.php, Editor Group 1
Review rate limit handli…, Editor Group 2
remote
app (Git) - JY-20725-handle-HS-search-rate-limit*, Checkout Branch/Tag...
JY-20725-handle-HS-search-rate-limit*
app (Git) - Synchronize Changes
Errors: 6, Warnings: 18, Infos: 4
6
18
4
Notifications
key, PHP extension: Premium features not active.
8.3, Language Level: 8.3
Sign In
Sign In
PHP
LF
UTF-8
Spaces: 4
Ln 308, Col 1
Diff editor
Clear
Review rate limit handling for HubSpot job queue
Session history
New session
Message actions
RateLimitException.php#9-9
RateLimitException.php#9-9
Reveiw the diff. Mostly
@app/Jobs/Crm/MatchActivityCrmData.php
,
@app/Exceptions/RateLimitException.php
,
@app/Jobs/Middleware/HandleHubspotRateLimit.php
,
@app/Services/Crm/Hubspot/Client.php
and
@app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php
. The issue is I am trying to make sure that instant spike of MatchActivityCrmData jobs willl handle 429 exceptions from hubspot. Revewi ti carefully and try to see potential issues and bottlenecks. Also RateLimitException was changerd from LogicException to RuntimeException. Is it ok. This exception is used by other paerts of code. Will ti break anything?
Thought for 5s
Thought for 5s
I'll review the implementation carefully. Let me first check how
RateLimitException
is used elsewhere and look at the test files and
PaginationState
.
Bash
Find all usages of RateLimitException outside the changed files
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/app --include="*.php" | grep -v "HandleHubspotRateLimit\|MatchActivityCrmData\|Client.php\|RateLimitException.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:17:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:68: RateLimitException |
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:15:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:58: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:19:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:76: RateLimitException |
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:50: * @throws RateLimitException When rate limit is hit
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php:195: // RateLimitException and other exceptions are re-thrown as-is
Read
PaginationState.php
PaginationState.php
Read
HandleHubspotRateLimitTest.php
HandleHubspotRateLimitTest.php
Bash
Check how RateLimitException is used in GenerateActionItemsJob
IN
grep -rn "RateLimitException\|LogicException\|RuntimeException" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -20
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
Bash
Find all catch blocks or instanceof checks for RateLimitException
IN
grep -rn "catch.*RateLimitException\|instanceof RateLimitException" /Users/lukas/jiminny/app/app --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:11: * Job middleware that catches RateLimitException from HubSpot API calls
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:24: } catch (RateLimitException $e) {
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:149: if (! $e instanceof RateLimitException) {
Bash
Find all test references to RateLimitException
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/tests --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:13:#[CoversClass(RateLimitException::class)]
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:14:class RateLimitExceptionTest extends TestCase
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:18: $exception = new RateLimitException();
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:28: $exception = new RateLimitException('Hubspot rate limit', 30, $previous);
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:52: $exception = new RateLimitException('test', $input);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:10:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:49: public function testPropagatesNonRateLimitExceptions(): void
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:103: throw new RateLimitException('rate limited', $retryAfter);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:150: throw new RateLimitException('rate limited', 1);
Bash
Check retry/failure handling in GenerateActionItemsJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -30
Copy code to clipboard
OUT
13:use Jiminny\Exceptions\RateLimitException;
51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
56: $this->release(30);
Bash
Check retry/failure handling in GenerateAiCallScoringJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php | head -30
Copy code to clipboard
OUT
17:use Jiminny\Exceptions\RateLimitException;
68: RateLimitException |
75: $this->release(30);
Bash
Check retry config in MatchActivityCrmData
IN
grep -n "retryAfter\|RETRY_WINDOW\|retryUntil\|maxTries" /Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php
Copy code to clipboard
OUT
34: private const int RETRY_WINDOW_MINUTES = 30;
45: public function retryUntil(): \DateTimeInterface
47: return now()->addMinutes(self::RETRY_WINDOW_MINUTES);
77: return self::RETRY_WINDOW_MINUTES * 60 + 60;...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app — 9 ✻ [Claude Code] Client.php (Client.php) — app — 9 problems in this file...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9, M
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php
ResponseNormalize.php
Service.php
SyncFieldAction.php
SyncRelatedActivityManager.php
WebhookSyncBatchProcessor.php
IntegrationApp
Listeners
Metadata
Migration
Pipedrive
OpportunitySyncStrategy
ProspectSearchStrategy
ApiFields.php
OpportunitySyncStrategy
Hubspot
Crm
Services
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
Client.php, Editor Group 1
✻ [Claude Code] Client.php (Client.php), Editor Group 1
HubspotPaginationService.php, Editor Group 1
Review rate limit handli…, Editor Group 2
remote
app (Git) - JY-20725-handle-HS-search-rate-limit*, Checkout Branch/Tag...
JY-20725-handle-HS-search-rate-limit*
app (Git) - Synchronize Changes
Errors: 6, Warnings: 18, Infos: 4
6
18
4
Notifications
key, PHP extension: Premium features not active.
8.3, Language Level: 8.3
Sign In
Sign In
PHP
LF
UTF-8
Spaces: 4
Ln 308, Col 1
Diff editor
Clear
Review rate limit handling for HubSpot job queue
Session history
New session
Message actions
RateLimitException.php#9-9
RateLimitException.php#9-9
Reveiw the diff. Mostly
@app/Jobs/Crm/MatchActivityCrmData.php
,
@app/Exceptions/RateLimitException.php
,
@app/Jobs/Middleware/HandleHubspotRateLimit.php
,
@app/Services/Crm/Hubspot/Client.php
and
@app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php
. The issue is I am trying to make sure that instant spike of MatchActivityCrmData jobs willl handle 429 exceptions from hubspot. Revewi ti carefully and try to see potential issues and bottlenecks. Also RateLimitException was changerd from LogicException to RuntimeException. Is it ok. This exception is used by other paerts of code. Will ti break anything?
Thought for 5s
Thought for 5s
I'll review the implementation carefully. Let me first check how
RateLimitException
is used elsewhere and look at the test files and
PaginationState
.
Bash
Find all usages of RateLimitException outside the changed files
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/app --include="*.php" | grep -v "HandleHubspotRateLimit\|MatchActivityCrmData\|Client.php\|RateLimitException.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:17:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:68: RateLimitException |
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:15:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:58: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:19:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:76: RateLimitException |
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:50: * @throws RateLimitException When rate limit is hit
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php:195: // RateLimitException and other exceptions are re-thrown as-is
Read
PaginationState.php
PaginationState.php
Read
HandleHubspotRateLimitTest.php
HandleHubspotRateLimitTest.php
Bash
Check how RateLimitException is used in GenerateActionItemsJob
IN
grep -rn "RateLimitException\|LogicException\|RuntimeException" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -20
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
Bash
Find all catch blocks or instanceof checks for RateLimitException
IN
grep -rn "catch.*RateLimitException\|instanceof RateLimitException" /Users/lukas/jiminny/app/app --include="*.php"
Copy code to clipboard...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app — 9 ✻ [Claude Code] Client.php (Client.php) — app — 9 problems in this file...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9, M
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php
ResponseNormalize.php
Service.php
SyncFieldAction.php
SyncRelatedActivityManager.php
WebhookSyncBatchProcessor.php
IntegrationApp
Listeners
Metadata
Migration
Pipedrive
OpportunitySyncStrategy
ProspectSearchStrategy
ApiFields.php
OpportunitySyncStrategy
Hubspot
Crm
Services
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
Client.php, Editor Group 1
✻ [Claude Code] Client.php (Client.php), Editor Group 1
HubspotPaginationService.php, Editor Group 1
Review rate limit handli…, Editor Group 2
remote
app (Git) - JY-20725-handle-HS-search-rate-limit*, Checkout Branch/Tag...
JY-20725-handle-HS-search-rate-limit*
app (Git) - Synchronize Changes
Errors: 6, Warnings: 18, Infos: 4
6
18
4
Notifications
key, PHP extension: Premium features not active.
8.3, Language Level: 8.3
Sign In
Sign In
PHP
LF
UTF-8
Spaces: 4
Ln 308, Col 1
Diff editor
Clear
Review rate limit handling for HubSpot job queue
Session history
New session
Message actions
RateLimitException.php#9-9
RateLimitException.php#9-9
Reveiw the diff. Mostly
@app/Jobs/Crm/MatchActivityCrmData.php
,
@app/Exceptions/RateLimitException.php
,
@app/Jobs/Middleware/HandleHubspotRateLimit.php
,
@app/Services/Crm/Hubspot/Client.php
and
@app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php
. The issue is I am trying to make sure that instant spike of MatchActivityCrmData jobs willl handle 429 exceptions from hubspot. Revewi ti carefully and try to see potential issues and bottlenecks. Also RateLimitException was changerd from LogicException to RuntimeException. Is it ok. This exception is used by other paerts of code. Will ti break anything?
Thought for 5s
Thought for 5s
I'll review the implementation carefully. Let me first check how
RateLimitException
is used elsewhere and look at the test files and
PaginationState
.
Bash
Find all usages of RateLimitException outside the changed files
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/app --include="*.php" | grep -v "HandleHubspotRateLimit\|MatchActivityCrmData\|Client.php\|RateLimitException.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:17:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:68: RateLimitException |
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:15:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:58: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:19:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:76: RateLimitException |
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:50: * @throws RateLimitException When rate limit is hit
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php:195: // RateLimitException and other exceptions are re-thrown as-is
Read
PaginationState.php
PaginationState.php
Read
HandleHubspotRateLimitTest.php...
|
Code
|
✻ [Claude Code] Client.php (Client.php) — app — 9 ✻ [Claude Code] Client.php (Client.php) — app — 9 problems in this file...
|
NULL
|
|
SlackFileEditViewGoHistoryWindowHelpAPP ()DOCKER0 SlackFileEditViewGoHistoryWindowHelpAPP ()DOCKER0 ₴1DEV (docker)₴2APP (-zsh)-zsh* @param string SobjectType The object type('deals''companies''contacts''cal)* @param array<string, mixed>Spayload Thesearch payload with filters, sorts, prope* @return array The search 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): arrayend 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 0ScrmService = ScrmResolver->prepareCrmService);-//-/1for ($i = 0; si < 3; Si++) {if (Si % 250) {Sthis->info("Syncing opportunity {Si}");Sthis->info("Matching contact {$i}");-1/-1/.+++++ScrmService->syncOpportunity('374720564');if ($i % 25=0{//Sthis->info("Syncing opportunity {$i}");Sthis->info("Matching contact {$i}");////}ScrmService->syncOpportunity('374720564');$crmService->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 containeror image →Learn more at https://docs.docker.com/go/debug-cli/lukas@Lukas-Kovaliks-MacBook-Pro-Jiminny ~/jiminny/app (JY-20725-handle-HS-search-rate-lir• 0EDHomeDMsActivityFilesLater..•More→Jiminny ...# contusion-clinic# curiosity_lab# engineering# general# jiminny-bg# platform-tickets# product_launches# random# releases# sofia-office# support# thank-yous# the_people_of jimi...• Direct messages®. Aneliya Angelova®. Galya DimitrovaPetko Kashinski&. Stefka StoyanovaVasil Vasilev&. Nikolay IvanovAneliya Angelova, ...Stoyan Tanev• VesE Lukas Kovalik y... OE:: Appsã Jira CloudToast100% <78• Mon 11 May 17:12:37Describe what you are looking for# support8 346 0MessagesC FilesBookmarksKara Joneswas added.Tuesday, April 28th~More v+Wednesday, April 29th ~Lauren Hudson 12:58 PMHi team, I'm trying to set up auto detect for LesMills, but when I add a new playbook (because theywant it applied across all teams), it's pulling in a loadof activity types that l am not able to delete. Anyideas please?Screenshot 2026-04-29 at 10.54.42.png •1 reply 12 days agoLauren Hudson 6:17 PMHello, request from Norstella to update theirJiminny to match this shared spreadsheet. lssomebody from the support team able to helpplease?Numbers Document •Message #support+...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
FirefoxEditVIewNew TabJy 20820 es reindex stream m FirefoxEditVIewNew TabJy 20820 es reindex stream mode# (UY-20725] [HubSpot] Optimise CFSevenShores Hi@ JY-20725 add HS rate limit har X© Pipelines - jiminny/app+ New TabHistory BookmarksProtllesToolsWindow HelpO github.com/jimir— have zero test coverage. In particular:• parseRetryAfter() : the Retry-After header parsing, fallback to message keyword matching, and thedefault-10-second case• isHubspotRateLimit() : each of the exception type branches• executerequest . tne cachea circul-breaker patn early throw wnen keais key exists, andtne sel nx pauwhen a live 429 is receivedThese are the most impactful paths to cover to get over the 70% gate.Minor observations5. Test constants duplicated from production codeHandleHubspotRateLimitTest.php re-declares MAX RETRY DELAY = 600. MIN_RETRY DELAY = 1. andJITTER SECONDS = 5 (lines 20-22). If these ever change in the middleware, the tests will silently use the old valuesand could still pass while testing the wrong bounds. Consider testing relative to the actual delay value returnedrather than hard-coding the expected range.6. Double-clamping in RateLimitExceptionThe constructor default SretryAfter = 1 (line 13) and getRetryAfter() calling max($this->retryAfter, 1) (line21) both guard against zero/negative values. The max() in the getter is unreachable given the current signaturedetault. Not a bua, but a minor inconsistency.7. RateLimitException in MatchActivityCrmData::failed()Ihe failedo hook (line 1/2) checks Sexception instanceof RateLimitExcedtion. but the middleware alwavs callsSjob->release() without re-throwing, so failed() would only fire for rate limit exceptions if the retryUntil()window expires with a pending rate-limit release, or if somehow the middleware is not applied. The check isdetensive and harmless. but worth notina in a comment since the nath is non-obvious)s8 This branch has not been deployedNo deploymentsAdd a commentWritoPreviewHB»0ssociationMulti;ption;iations as DealWithfervice:ine';$0100% L2Mon 11 May 17:12:370 000• 2 C;→ Review rate limit handli...*Keview fate lmit nanaling tor nuospouo..< Client.php#62-168Add coverage of new methods in Client public function search(string $objectType, array Spayload): array• Thought for 21s ?• Bash Check if ClientTest has tearDown or Mockery cleanurgrep -n "tearDown\ |Mockery::close\ |MockeryPHPUnit" /Users/lukas/jiminny/app/tests/Unit/Services/Crm/Hubspot/ClientTest.php | head -10OUT (Bash comoleted with no outout)• Bash Check existina imoorts for APl excentions in ClientTestgrep -n "DealApiException vicontactApiExceptiion V ICompanyApiExcepti on V Rate !mitException" 7Users/Lukas/#lminny/apo//tests/Unit7/Services/crm /Hubspot/cuentrest. pho head =10OUT (Bash completed with no output)• Thought for 1s ›• Now I have a clear picture. Let me write the new tests. I'll add them to the end of ClientTest.php (before the closing } ), with the necessary imports added at the top• Read ClientTest.php• Now I'll add the necessary imports and test methods:• Edit ClientTest.ohouse GuzZleHtto Psr/ Response:ciations\Api\BatchApi;use HubSpot\Client\Crm\Associations\Mocuse nusporrelentiem assocraczons modelruo Licoo ecteo,use nubsootsePubLicAssociationMulti.use HubSpot\CLient\Crm\Deals\Api\BasicApi as DealsBasicApi;lodel\Puo Licob ectlo• use nubspot cllent crm companzes Apicxcepcion as companyapiexcepclonuse Hubspot Client crm contacts ApiException as contactAp1Exception;use Hubspot clent crm deals Aoi BasicAdi as DealsbasicAo1:use HubSpot\CLient\Crm\Deals\Model|SimplePublicObjectWithAssociations asuse HubSpot\Client\Crm\Deals\Model\SimplePublicObjectWithAssociations asMake this edit to ClientTest.php?11 Yes7Yes. alllow all edits this session3 NoTell Claude what to do insteadEsc to cancelLn 12, Col 1 Spaces: 4 UTF-8 LF PHP 8 Sign In 8.3 g...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
selectionViewlerminalWindowm RateLimitException.ohdUsers > lukas › jiminny › app › tests > Unit > Services > Crm > Hubspot › #* ClientTest.php100% L2Mon 11 May 17:13:28EXPLORERV APPV appv Serviceserm• Hubspol~OpportunitySyncStrategy..• HubsnotL astModified@nenSvncStra..# HubspotLastModifiedSyncStrategy....• HubsootSinaleSvncStrategy.onp## HubspotSyncStrategyBase.php# HubsnotWebhookBatchSyncstrateg.V Dadinationi# HubspotPaginationService.php# PaginationConfig.php# PaginationState.phpProspectsearchstrategy) Dodic~ Servicelraits# OpportunitySyncTrait.php• SvncCrmEntitiesTrait.phpwsuncrields.rait.ono• WriteCrmTrait.phr• Utils• WebhookBatchSvncCollector.phoBatchSvncRedisService.ohvClient.oho* ClosedDealStagesService.oho* DealFieldsService.oho* DecorateActivitv.oho•FieldDefinitions.ohn• FieldTvoeConverter.oho# HubspotClientinterface.php# HubspotTokenManager.php€ DavloadRuilder nhnRemoteCrmObjectManipulator.php«* PecnonceNormalize nhn• Service.php# SyncFieldAction.php• SuncPelatedActivitvManager.php# WebhookSyncBatchProcessor.php> IntearationApp• Listeners> Metadata> MigrationV Pipedrive• OpportunitySvncStrateav• ProspectSearchStrateavOUTIINETIMELINGia JY-20725-handle-HS-search-rate-limit* @26A902#Client.oho 9"* Claude Code Clientlest.oho X« HubspotPaginati * % 00 M→ = Review rate limit handli..Review rate limit handling for HubSpot jo...<› Client.nhn#62-1681Add coverage of new methods in Client public function search(string $objectType, array Spayload): array• Now I have a clear picture. Let me write the new tests. I'll add them to the end of ClientTest.php (before the closing } ), with the necessary imports added at the top• Read ClientTest.php• Now l'll add the necessary imports and test methods:• Edit CLientTest.ohouse Guzzlehtto Psrz Response:use HubSoot Cuient Crm Associations Ao1 BatchAoi:use HubSnot Client| Crm Associationc|Mode BatchTnnutPuhlic0hiecttd:use HubSnot\Client|CrnlAçsociations|Model\RatchReçnonsePublicAcsociationMulti•use HubSpot\Client\Crm\Deals\Api\BasicApi as DealsBasicApi;use HubSpot\CLient\Cm\Dea1s Mode1(5imp LePubLicObj ectwithAssociations as• Now add the new test methods before the closing }• Edit ClientTest.phppublic function testRemoveAssociations(): voidSobiectType = 'deals':= 'contacts':inouts' =['from' » ('id' » 'deal1'], 'to' » ['id' = 'contact1']],use Guzzlehtto Psrz Resoonse:use HubSoot Cuient Crn Associations Api BatchApi:use HubSnot.Client.CrmlAssociations.ModeBatchTnnutPuhlic0hiecttdeuse HubSnot\Client\Crm|Açsociations|Mode1\RatchReçnonsePublicAçsociationMulti.HubSpot (C/1ent Crbeats VoESimorus cotieExceptSsoctations a5public function testRemoveAssociations(): voidsobiectlype = "dealssassociat ionivoe"contacts'inouts' =('from' = ('id' = 'deal1'), 'to' = ('id' = 'contact1')),"success':Make this edit to CLientTest.php?1Yes1 Yes. alllow all edits this session3 NoTell Claude what to do insteadEsc to cancel88 SignIn...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
v App~ Opportunity SyncStratey...• HubsnotLastModi v App~ Opportunity SyncStratey...• HubsnotLastModified@nenSvncStra..# HubspotLastModifiedSyncStrategy....# HubsootSinaleSyncstrategy.onp## HubspotSyncStrategyBase.php# HubsnotWebhookBatchSyncstrateg.Pagination# HubspotPaginationService.php# PaginationConfig.php# PaginationState.phpProspectsearchstrategy→Hoal~ Servicelraits#Opportunitysyncirait.php• SvncCrmEntitiesTrait.phpwsuncrields.rait.ono• WriteCrmTrait.phr• Utils• Webhookw BatchSvncCollector.oho# BatchSvncRedisService.ohoCliient.oho* ClosedDealStagesService.oho* DealFieldsService.oho* DecorateActivitv.oho• FieldDefinitions.ohn• FieldTvneConverter.ohn# HubspotClientinterface.php• HubsootTokenManager.onp€ DavloadRuilder nhn# RemoteCrmObjectManipulator.php«* PecnonceNormalize nhnw service.php#R SyncFieldAction.php# SynckelatedActivityManager.php# WebhookSyncBatchProcessor.phpIntearationapo› MetadataHandleHubspotRateLimit.phpClient.php 9* [Claude Codel ClientTest.php X90inny › app › tests › Unit › Services › Crm > Hubspot › « ClientTest.php › 9g ClientTestClienttest extends Testcaseclass Clienttest extends Testcasepub lic tunction testRemoveAssoclations: vo1d1778Sthis->assertSame($expectedResponse, Sresult);$this->assertSame($expectedResponse, Sresult);search() / executeRequest() tests$redisMock = Mockery::mock('alias:Illuminate\Support\Facades\Redis');sredtsmock→>shoulakecervel get→oncel→›andketurhnutehsth1s→>cont10=>method(getid)→>w1llReturn(42);Soavload = 'filters' =>00:Sresponselata = 'results' as Td s 1'r 'total e> 1, nadina' =>athic_shubsnotclientMockSoynocte(sthie soncol))Client::BASE URL . '/crm/v3/obiects/contacts/search'.>willReturn(ShubspotResponse:Sresult = Sthis->client-ssearch/ "contacts'. Snavload).senis->asserrtoane sresponsevata, SresulunMockery::closeGredicMock = Mockerve.mock/laliac,Tlluminatel Sunnortl Facadec) Redict)•Sthis->cont1o->methoddetid") ->w1u Return(42):sthis-shubsnotclentMock-sexnects/Sthic-snevero=smethod/request'schis->expectexcepczonmessacel nuospor race limit (cached circult-oreaker.trysthis->client->search"contacts'.finallyMockerv::closed:PA 1M 20725100% L2Mon 11 May 17:13:31• 2 C→ = Review rate limit handli..Keview fate lmit nanaling for nuospouo..<› Client.nhn#62-1681Add coverage of new methods in Client public tunction search(string sobiectlype, array spayload): array• Now I have a clear picture. Let me write the new tests. I'll add them to the end of ClientTest.php (before the closing } ), with the necessary imports added at the top• Read ClientTest.ohp• Now I'll add the necessary imoorts and test methods:• cait clentrest.phpuse Hubspot Cllent crm Associations Ap1 BatchAp1use Hubsoot cllent crm Associations Mode BatchinoutPub lacoblectid:use HubSpot Client Crm Associations Model BatchResponsePublicAssociat ionMult 1:use Hubsoot cuient Crn Associations Model Publicobiectid:use HubSpot\Client\Crm\Deals\Api\BasicApi as DealsBasicApi;use HubSpot\Client\Crm\ Deals\Model\SimplePublic0biectWithAssociations as• Now add the new test methods before the closing } :• Edit ClientTest.ohopublic function testRemoveAssociations(): void"deals';SassociationType = 'contacts':Spayload =('from' => ('id' => 'deal1'], 'to' => ('id' => 'contact1']].use buzzlencco rsr/ kesponseuse Hubspot Cllent crm assoclations Ap1 BatchAp1;use Hubsoot cllent crm Associations Mode BatchinoutPub lacoblectid:use HubSoot Client Crm Associations Model BatchResponsePuolicAssociationMulti:use HubSoot cuient Crn Associations Model Pubuicobiectildause HubSnot\ Client\ Crml Comnanies AniExcention as ComnanvAniExcention:use HubSpot\Client\ Crm\Deals\Model\SimplePublic0biectWithAssociations aspublic function testRemoveAssociations(): voidSassociationType = 'contacts':spay load =('from' = ['id' => 'deal1'], 'to' = ('id' => 'contact1']].notResnonse(('statust = "succecc'1):Make this edit to CLientTest.php?7Yes. alllow all edits this session3 NoEsc to canceLn 1799, Col 1 Spaces:4 UTF-8 LF PHP 8 SignIn 8.3 P...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
Users > lukas > jiminny › app › tests › Unit › Services > Crm › Hubspot › # ClientTest.php › • ClientTestClient.php 9* [Claude Codel ClientTest.php X12791class Clienttest extends Testcase1864public tunction testSearchReturnsDecodedArrav0nSuccess: vo1d1823t~ Opportunity SyncStratey...• HubsnotLastModified@nenSvncStra.# HubspotLastModifiedSyncStrategy..• HubsootSinaleSvncStrategy.onp## HubspotSyncStrategyBase.php# HubsnotWebhookBatchSyncstrateg.Pagination# HubspotPaginationService.php# PaginationConfig.phpwPaginationstate.phpProspectsearchstrategy#Opportunitysyncirait.php• SvncCrmEntitiesTrait.phpwsuncrields.rait.ono• Utils• Webhookw BatchSvncCollector.oho# BatchSvncRedisService.ohoCliient.oho* ClosedDealStagesService.oho* DealFieldsService.oho• DecorateActivitv.oho• FieldDefinitions.ohn• FieldTvneConverter.ohn# HubspotClientinterface.php• HubsootTokenManager.onp€ DavloadRuilder nhn# RemoteCrmObjectManipulator.php*• PecnonceNormalize nhnw service.php# SyncFieldAction.php# SynckelatedActivityManager.phpIntearationADooublie function tectCearchThrowcPatel_imi+FycentionbhenGircuitRreakerdctive/).Stuturerimestamp = (string) (Cime() + 36);SredisMock-sshouldReceive( 'aet'->once@->andReturn(SfutureTimestamo•scnas-contigonecnod getto owetthecurm,42),schis→>nuospocculentmock→>expects schis-never→mechodrequestrsthis→>expectExcention Rateumit-xceot 1on::class)^sthis->expectExceptzon(Rateuemtexceptzonte tasst: (cached circuit-breaker'$this->client->search('contacts', 0);Mockery:: close():public function testSearchThrowsRateLimitExceptionAndSetsNx0nFresh429(): void$redisMock = Mockery::mock('alias:Illuminate\Support\Facades\Redis');Sreasmock»>shoulakecervel ger→oncel→anakecurmnutunsrea1smock→>shou lakeceivel ser')"nuospot.ratelumit.oortal:42',Mockery:: type('string"),'ey' => 11sch1s→>cont10→>mechod( gecla)→>w1llketurn(42);cnsualooalllaetenew BadRequest 'Rate Limit exceeded", 429):-wil1ThrowExcention/ShadRequest)Sthis->expectException(RateLimitException::class):Sthis->expectExceptionMessage('Hubspot returned 429'):trysthis-sclient-ssearch"contacts'. "finally 4Mockerv.closel)SredisMock = Mockerv: :mocklalias: u luminate Sunnort Facades Redis'MYSOLPA 1M 20725100% LzMon 11 May 17:14:04• 2 C→ = Review rate limit handli..Keview fate lmit nanaling for nuospouo..<› Client.nhn#62-1681Add coverage of new methods in Client public tunction search(string sobiectlype, array Spayload): array• Now I have a clear picture. Let me write the new tests. I'll add them to the end of ClientTest.php (before the closing } ), with the necessary imports added at the top• Read Clienttest.ohp• Now I'll add the necessary imoorts and test methods:• cait clentrest.phouse GuzzleHttp\Psr7\Responseuse HubSpot\Client\Crm\Associations\Api\BatchApiuse Hubsoot cllent crm Associations Mode BatchinoutPub lacoblectid:use HubSpot Client Crm Associations Model BatchResponsePublicAssociat ionMult 1:use Hubsnot cuient Crn Associations Model Publicobiectiduse HubSpot\Client\Crm\Deals\Api\BasicApi as DealsBasicApi;use HubSpot\Client\Crm\ Deals\Model\SimplePublic0biectWithAssociations as• Now add the new test methods before the closing } :• Edit ClientTest.ohopublic function testRemoveAssociations(): void'deals';SassociationType = 'contacts':Spayload =('from' => ('id' => 'deal1'], 'to' => ('id' => 'contact1']].rateHubSnotRecnonse/f'status! →Make this edit to CLientTest.php?7Yes. alllow all edits this session3 NdEsc to canceuse buzzlencco rsr/ kesponseuse Hubspot Cllent crm Associations Ap1 BatchAp1;use Hubsoot cllent crm Associations Mode BatchinoutPuo lacoblectid:use HubSoot Client Crm Associations Model BatchResponsePuolicAssociationMulti:use HubSoot cuient Crn Associations Model Publicobiectidause HubSnot\ Client\ Crml Comnanies AniExcention as ComnanvAniExcention:use HubSpot\Client\ Crm\Deals\Model\SimplePublic0biectWithAssociations aspublic function testRemoveAssociations(): voidSassociationType = 'contacts':spay load =('from' = ['id' => 'deal1'], 'to' => ('id' => 'contact1']].notResnonse(('statust = Isuccecs'1):Ln 1799, Col 1 Spaces:4 UTF-8 LF PHP 8 SignIn 8.3 P...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 13 pending changes
13
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G)
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G)
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 15 pending changes
*SelectionViewGoWindow< → * [Claude Code] ClientTest.php (ClientTest.php) - appEXPLORERlatchActivitvcrmData.oho* Client.php 9, M14 * [Claude Code] ClientTest.php 9+ XUsers > lukas > jiminny > app › tests › Unit > Services > Crm > Hubspot > e ClientTest,php > gg ClientTest > © testSearchThrowsRateLimitEceptionAndSetsNxOnFresh4290)class Clientrest extends Testcase1828public function testSearchThrowsRateLimitExceptionWhenCircuitBreakerActiv1828class Clienttest extends Testcasepublic function testSearchThrowsRateLimitExceptionWhenCircuitBreakerActive():18291829|1830Stuturelnmestamo = (string) timeo ÷ 30)183011~ Opportunity SyncStratey...18311831|1832SredisMock = Mockerv:.mock(lalias:Tlluminate\ Sunnort\ Facades|Redis!)•** HubspotLastModifiedOpenSyncStra...183318321833** HubspotLastModifiedSyncStrategy....чR HubspotSingleSyncStrategy.phpsthis->config->method ('getId')->willReturn(42);1834** HubspotSyncStrategyBase.phpsthis->hubspotclientMock->expects(Sthis->nevero->methodrequest':** HubspotWebhookBatchSyncStrateg...Pagination* HubspotPaginationService.phpSthis->expectExceptionMessage('Hubspot rate limit (cached circuit-bresthis->expectException(RateLimitException::class);$this->expectExceptionMessage('Hubspot rate limit (cached circuit-breaker)* PaginationConfig.phpa PaginationState.php> ProspectSearchStrategy> Redistry{sthis->client->search('contacts', (1);finally &Mockery: :close();~ Servicelraits# OpportunitySyncTrait.php4 SyncCrmEntitiesTrait.phppublic function testSearchThrowsRateLimitExceptionAndSetsNx0nFresh429():# SyncFieldsTrait.phpSredisMock = Mockery::mock('alias:Illuminate\Support\ Facades\Redis'):18421843184418451184611847|1848|18491850try{sthis->client->search('contacts', ());y finally &Mockerv::closed:public function testSearchThrowsRateLimitExceptionAndSetsNxOnFresh429(): voidrodicMock = Mockerv:«mock( 'alias:Tuluminate Support Facades Redis ;44 WriteCrmTrait.php• Utils1853• Webhookexact TTL depends on parseRetryAfter, verifiedSredisMock->shouldReceive('set*)BatchSvncCollector.ohoBatchSvncRedisService.ohvI Cllient.oho9, M|• ClosedDea|StagesService.ohoubspot: ratelimit:portal:42',lockery: : type('string'),Mockery: :on(fn ($opts) = is_array($opts) && in_array('nx', !hubspot:ratelimit:config:42',посkeгy:: cype( Suring),* DealFieldsService.oho# DecorateActivity.php•FieldDefinitions.ohn# FieldTypeConverter.php# HubspotClientinterface.phpsthis->config->method('getId')->willReturn(42);SbadRequest = new BadRequest( 'Rate limit exceeded', 429);Sthis->hubspotClientMockShadRequest = new BadRequest('Rate Limit exceeded' 429)•thic_shuhsnotclientMock_seynectc/sthic-soncel)y# HubspotTokenManager.php€ DavloadRuilder nhn->willThrowException($badRequest);RemoteCrmObjectManipulator.phpResponseNormalize.phpR Service.php# SyncFieldAction.php4 SyncRelatedActivityManager.php# WebhookSyncBatchProcessor.php› IntegrationApp• Listeners> MetadataMiarationV Pipedrive65655361877187:187918801881190%186018611862186318641865|1866186718681869Sthis->expectExceptionMessage('Hubspot returned 429');Sthis->expectExcentiion(RateLimitExcention::class)Sthis->expectExceptionMessage('Hubspot returned 429');Sthis-ellent-»search( " contacts', (1):y finally {Mockery: : close();try {sthis->client->search('contacts', I1):j finally €Mockery: : close();nublic function tectCearchPronagatecNonPatel imitFycentiono voidCrodicMock - Mockorve.mock/Ialiac.TlluminatolGunnortlFocadoc|Podic!)187811879|1880|1881|1902|nublic function tectSearchPronanatecNonPatel imi+Fycentiono voidrodicMock - Mockorve.mock/ialiac,Tlluminatol Gunnortl Gacadoc|Podict).ProspectSearchStrateav> OUTLINE> TIMELINEsthis->confiq->method("getid')->willReturn(42):Pa JY-20725-handle-HS-search-rate-limit* ©© 36 4 8 0 26sthis->confiq->methodgetid'->willReturn(42):Sexception = new \SevenShores \Hubspot\Exceptions \HubspotException("Servei•2 C3→ = Review rate limit handli..Review rate limit handling for HubSpot jo...Here are code reveiw suagestions: IssuesSresults = Sthis->processApiResults(Sresponse);• Edit RateLimitException.phpclass RateLimitException extends RuntimeExceptionpublic functionstringconstructiprivate readonly int SretryAfter = 1,"inrowable sprevious = nuul,• Now fix issue 7 - add a comment in MatchActivityCrmData:: failed():• Edit MatchActivitvGrmData.ohdAdded 3 linesMake this edit to ClientTest.php?7Yes. alllow all edits this session3 NoTell Claude what to do insteadEsc to cance100% L2Mon 11 May 17:43:31Creculte = Cthic-snroceccAniReculte/cracnance)class KateLimitexcepcion extenos kuncimeexceptionprivate readonly int SretrvAtter:public function?Throwable $previous = null,parent:: construct smessage, , Sprevious):RateLimitExcention reaches failedo only when retrvuntilo exoires whillethe 10b is#still held in the "released" state bv HandleHubsnotRateLimit = the// re-throws, so the exception is not the direct cause of the failure infe famneeatfen Jaetaaeaad AetafSafkRuatatieo 'hubspot:ratelimit:config:42'Ln 1857, Col 1 Spaces: 4 UTF-8 LF PHP 8 Signin 8.3 g...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 15 pending changes
15
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9, M
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php
ResponseNormalize.php
Service.php
SyncFieldAction.php
SyncRelatedActivityManager.php
WebhookSyncBatchProcessor.php
IntegrationApp
Listeners
Metadata
Migration
Pipedrive
OpportunitySyncStrategy
ProspectSearchStrategy
ApiFields.php
OpportunitySyncStrategy
Hubspot
Crm
Services
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
Client.php, Editor Group 1
✻ [Claude Code] ClientTest.php (ClientTest.php), Editor Group 1
HubspotPaginationService.php, Editor Group 1
Review rate limit handli…, Editor Group 2
remote
app (Git) - JY-20725-handle-HS-search-rate-limit*, Checkout Branch/Tag...
JY-20725-handle-HS-search-rate-limit*
app (Git) - Synchronize Changes
Errors: 36, Warnings: 9, Infos: 26
36
9
26
Notifications
key, PHP extension: Premium features not active.
8.3, Language Level: 8.3
Sign In
Sign In
PHP
LF
UTF-8
Spaces: 4
Ln 1857, Col 1
Diff editor
Clear
Review rate limit handling for HubSpot job queue
Session history
New session
Message actions
RateLimitException.php#9-9
RateLimitException.php#9-9
Reveiw the diff. Mostly
@app/Jobs/Crm/MatchActivityCrmData.php
,
@app/Exceptions/RateLimitException.php
,
@app/Jobs/Middleware/HandleHubspotRateLimit.php
,
@app/Services/Crm/Hubspot/Client.php
and
@app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php
. The issue is I am trying to make sure that instant spike of MatchActivityCrmData jobs willl handle 429 exceptions from hubspot. Revewi ti carefully and try to see potential issues and bottlenecks. Also RateLimitException was changerd from LogicException to RuntimeException. Is it ok. This exception is used by other paerts of code. Will ti break anything?
Thought for 5s
Thought for 5s
I'll review the implementation carefully. Let me first check how
RateLimitException
is used elsewhere and look at the test files and
PaginationState
.
Bash
Find all usages of RateLimitException outside the changed files
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/app --include="*.php" | grep -v "HandleHubspotRateLimit\|MatchActivityCrmData\|Client.php\|RateLimitException.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:17:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:68: RateLimitException |
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:15:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:58: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:19:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:76: RateLimitException |
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:50: * @throws RateLimitException When rate limit is hit
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php:195: // RateLimitException and other exceptions are re-thrown as-is
Read
PaginationState.php
PaginationState.php
Read
HandleHubspotRateLimitTest.php
HandleHubspotRateLimitTest.php
Bash
Check how RateLimitException is used in GenerateActionItemsJob
IN
grep -rn "RateLimitException\|LogicException\|RuntimeException" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -20
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
Bash
Find all catch blocks or instanceof checks for RateLimitException
IN
grep -rn "catch.*RateLimitException\|instanceof RateLimitException" /Users/lukas/jiminny/app/app --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:11: * Job middleware that catches RateLimitException from HubSpot API calls
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:24: } catch (RateLimitException $e) {
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:149: if (! $e instanceof RateLimitException) {
Bash
Find all test references to RateLimitException
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/tests --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:13:#[CoversClass(RateLimitException::class)]
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:14:class RateLimitExceptionTest extends TestCase
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:18: $exception = new RateLimitException();
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:28: $exception = new RateLimitException('Hubspot rate limit', 30, $previous);
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:52: $exception = new RateLimitException('test', $input);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:10:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:49: public function testPropagatesNonRateLimitExceptions(): void
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:103: throw new RateLimitException('rate limited', $retryAfter);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:150: throw new RateLimitException('rate limited', 1);
Bash
Check retry/failure handling in GenerateActionItemsJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -30
Copy code to clipboard
OUT
13:use Jiminny\Exceptions\RateLimitException;
51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
56: $this->release(30);
Bash
Check retry/failure handling in GenerateAiCallScoringJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php | head -30
Copy code to clipboard
OUT
17:use Jiminny\Exceptions\RateLimitException;
68: RateLimitException |
75: $this->release(30);
Bash
Check retry config in MatchActivityCrmData
IN
grep -n "retryAfter\|RETRY_WINDOW\|retryUntil\|maxTries" /Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 15 pending changes
15
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9, M
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php
ResponseNormalize.php
Service.php
SyncFieldAction.php
SyncRelatedActivityManager.php
WebhookSyncBatchProcessor.php
IntegrationApp
Listeners
Metadata
Migration
Pipedrive
OpportunitySyncStrategy
ProspectSearchStrategy
ApiFields.php
OpportunitySyncStrategy
Hubspot
Crm
Services
app
Outline Section
OUTLINE
OUTLINE
Timeline Section
TIMELINE
TIMELINE
MySQL Section
MYSQL
MYSQL
MatchActivityCrmData.php, Editor Group 1
RateLimitException.php, Editor Group 1
HandleHubspotRateLimit.php, Editor Group 1
Client.php, Editor Group 1
✻ [Claude Code] ClientTest.php (ClientTest.php), Editor Group 1
HubspotPaginationService.php, Editor Group 1
Review rate limit handli…, Editor Group 2
remote
app (Git) - JY-20725-handle-HS-search-rate-limit*, Checkout Branch/Tag...
JY-20725-handle-HS-search-rate-limit*
app (Git) - Synchronize Changes
Errors: 36, Warnings: 9, Infos: 26
36
9
26
Notifications
key, PHP extension: Premium features not active.
8.3, Language Level: 8.3
Sign In
Sign In
PHP
LF
UTF-8
Spaces: 4
Ln 1857, Col 1
Diff editor
Clear
Review rate limit handling for HubSpot job queue
Session history
New session
Message actions
RateLimitException.php#9-9
RateLimitException.php#9-9
Reveiw the diff. Mostly
@app/Jobs/Crm/MatchActivityCrmData.php
,
@app/Exceptions/RateLimitException.php
,
@app/Jobs/Middleware/HandleHubspotRateLimit.php
,
@app/Services/Crm/Hubspot/Client.php
and
@app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php
. The issue is I am trying to make sure that instant spike of MatchActivityCrmData jobs willl handle 429 exceptions from hubspot. Revewi ti carefully and try to see potential issues and bottlenecks. Also RateLimitException was changerd from LogicException to RuntimeException. Is it ok. This exception is used by other paerts of code. Will ti break anything?
Thought for 5s
Thought for 5s
I'll review the implementation carefully. Let me first check how
RateLimitException
is used elsewhere and look at the test files and
PaginationState
.
Bash
Find all usages of RateLimitException outside the changed files
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/app --include="*.php" | grep -v "HandleHubspotRateLimit\|MatchActivityCrmData\|Client.php\|RateLimitException.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:17:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiCallScoring/Jobs/GenerateAiCallScoringJob.php:68: RateLimitException |
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:15:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/TranscriptionSummary/Jobs/SummarizeTranscriptionJob.php:58: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:19:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/AiActivityType/Jobs/GenerateAiActivityTypeJob.php:76: RateLimitException |
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/HubspotClientInterface.php:50: * @throws RateLimitException When rate limit is hit
/Users/lukas/jiminny/app/app/Services/Crm/Hubspot/Pagination/HubspotPaginationService.php:195: // RateLimitException and other exceptions are re-thrown as-is
Read
PaginationState.php
PaginationState.php
Read
HandleHubspotRateLimitTest.php
HandleHubspotRateLimitTest.php
Bash
Check how RateLimitException is used in GenerateActionItemsJob
IN
grep -rn "RateLimitException\|LogicException\|RuntimeException" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -20
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:13:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php:51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
Bash
Find all catch blocks or instanceof checks for RateLimitException
IN
grep -rn "catch.*RateLimitException\|instanceof RateLimitException" /Users/lukas/jiminny/app/app --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:11: * Job middleware that catches RateLimitException from HubSpot API calls
/Users/lukas/jiminny/app/app/Jobs/Middleware/HandleHubspotRateLimit.php:24: } catch (RateLimitException $e) {
/Users/lukas/jiminny/app/app/Jobs/Crm/MatchActivityCrmData.php:149: if (! $e instanceof RateLimitException) {
Bash
Find all test references to RateLimitException
IN
grep -rn "RateLimitException" /Users/lukas/jiminny/app/tests --include="*.php"
Copy code to clipboard
OUT
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:8:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:13:#[CoversClass(RateLimitException::class)]
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:14:class RateLimitExceptionTest extends TestCase
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:18: $exception = new RateLimitException();
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:28: $exception = new RateLimitException('Hubspot rate limit', 30, $previous);
/Users/lukas/jiminny/app/tests/Unit/Exceptions/RateLimitExceptionTest.php:52: $exception = new RateLimitException('test', $input);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:10:use Jiminny\Exceptions\RateLimitException;
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:49: public function testPropagatesNonRateLimitExceptions(): void
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:103: throw new RateLimitException('rate limited', $retryAfter);
/Users/lukas/jiminny/app/tests/Unit/Jobs/Middleware/HandleHubspotRateLimitTest.php:150: throw new RateLimitException('rate limited', 1);
Bash
Check retry/failure handling in GenerateActionItemsJob
IN
grep -n "RateLimitException\|retryUntil\|backoff\|maxExceptions\|maxTries\|release\|failed" /Users/lukas/jiminny/app/app/Component/ActionItems/Jobs/GenerateActionItemsJob.php | head -30
Copy code to clipboard
OUT
13:use Jiminny\Exceptions\RateLimitException;
51: GuzzleException|HttpBadRequestException|JsonException|RateLimitException|UnexpectedValueException $exception
56: $this->release(30);
Bash...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 15 pending changes
15
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9, M
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php
ResponseNormalize.php
Service.php
SyncFieldAction.php
SyncRelatedActivityManager.php
WebhookSyncBatchProcessor.php
IntegrationApp
Listeners
Metadata
Migration
Pipedrive
OpportunitySyncStrategy
ProspectSearchStrategy
ApiFields.php
OpportunitySyncStrategy...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 15 pending changes
15
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
Concerns
HubspotLastModifiedByProfileSyncStrategy.php
HubspotLastModifiedCreatedRecentlyOpenSyncStrategy.php
HubspotLastModifiedCreatedRecentlySyncStrategy.php
HubspotLastModifiedOpenSyncStrategy.php
HubspotLastModifiedSyncStrategy.php
HubspotSingleSyncStrategy.php
HubspotSyncStrategyBase.php
HubspotWebhookBatchSyncStrategy.php
Pagination
HubspotPaginationService.php
PaginationConfig.php
PaginationState.php
ProspectSearchStrategy
Redis
ServiceTraits
OpportunitySyncTrait.php
SyncCrmEntitiesTrait.php
SyncFieldsTrait.php
WriteCrmTrait.php
Utils
Webhook
BatchSyncCollector.php
BatchSyncRedisService.php
Client.php
9, M
ClosedDealStagesService.php
DealFieldsService.php
DecorateActivity.php
FieldDefinitions.php
FieldTypeConverter.php
HubspotClientInterface.php
HubspotTokenManager.php
PayloadBuilder.php
RemoteCrmObjectManipulator.php...
|
Code
|
✻ [Claude Code] ClientTest.php (ClientTest.php) — ✻ [Claude Code] ClientTest.php (ClientTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 16 pending changes
16
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
...
|
Code
|
✻ [Claude Code] HandleHubspotRateLimitTest.php (Ha ✻ [Claude Code] HandleHubspotRateLimitTest.php (HandleHubspotRateLimitTest.php) — app...
|
NULL
|
|
Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧ Explorer (⇧⌘E)
Search (⇧⌘F)
Source Control (⌃⇧G) - 16 pending changes
16
Run and Debug (⇧⌘D)
Remote Explorer
Extensions (⇧⌘X) - 2 require update
2
Testing
Claude Code
EXPLORER
EXPLORER
Explorer Section: app
Explorer Section: app
APP
Metadata
OpportunitySyncStrategy
...
|
Code
|
✻ [Claude Code] HandleHubspotRateLimitTest.php (Ha ✻ [Claude Code] HandleHubspotRateLimitTest.php (HandleHubspotRateLimitTest.php) — app...
|
NULL
|