PHP hook, building hooks in your application
Introduction
One of the real challenges in building any type of framework, core or application is making it possible for the developers to hook into the business logic at specific points. Since PHP is not event based, nor it works with interrupts you have to come up an alternative.
The test case
Lets assume we are the main developers of a webshop framework. Programmers can use our framework to build complete webshops. Programmers can manage the orders that are placed on the webshop with the order class. The order class is part of our framework and we don’t want it to be extended by any programmer. However we don’t want to limit to programmers in their possibilities to hook into the orders process.
For example programmers should be able to send an email to the webshopowner if an order changes from one specific delivery status to another. This functionality is not part of the default behavior in our framework and is custom for the progammers webshop implementation.
Like said before, PHP doesn’t provide interrupts or real events so we need to come up with another way to implement hooks into our application. Lets take a look at the observer pattern.
Implementing the Observer pattern
The observer pattern is a design-pattern that describes a way for objects to be notified to specific state-changes in objects of the application.
For the first implementation we can use SPL. The SPL provides in two simple objects:
SPLSubject
- attach (new observer to attach)
- detach (existing observer to detach)
- notify (notify all observers)
SPLObserver
- update (Called from the subject (i.e. when it’s value has changed).
iOrderRef = $iOrderRef;
// Get order information from the database or an other resources
$this->iStatus = Order::STATUS_SHIPPED;
}
/**
* Attach an observer
*
* @param SplObserver $oObserver
* @return void
*/
public function attach(SplObserver $oObserver)
{
$sHash = spl_object_hash($oObserver);
if (isset($this->aObservers[$sHash])) {
throw new Exception('Observer is already attached');
}
$this->aObservers[$sHash] = $oObserver;
}
/**
* Detach observer
*
* @param SplObserver $oObserver
* @return void
*/
public function detach(SplObserver $oObserver)
{
$sHash = spl_object_hash($oObserver);
if (!isset($this->aObservers[$sHash])) {
throw new Exception('Observer not attached');
}
unset($this->aObservers[$sHash]);
}
/**
* Notify the attached observers
*
* @param string $sEvent, name of the event
* @param mixed $mData, optional data that is not directly available for the observers
* @return void
*/
public function notify()
{
foreach ($this->aObservers as $oObserver) {
try {
$oObserver->update($this);
} catch(Exception $e) {
}
}
}
/**
* Add an order
*
* @param array $aOrder
* @return void
*/
public function delete()
{
$this->notify();
}
/**
* Return the order reference number
*
* @return int
*/
public function getRef()
{
return $this->iOrderRef;
}
/**
* Return the current order status
*
* @return int
*/
public function getStatus()
{
return $this->iStatus;
}
/**
* Update the order status
*/
public function updateStatus($iStatus)
{
$this->notify();
// ...
$this->iStatus = $iStatus;
// ...
$this->notify();
}
}
/**
* Order status handler, observer that sends an email to secretary
* if the status of an order changes from shipped to delivered, so the
* secratary can make a phone call to our customer to ask for his opinion about the service
*
* @package Shop
*/
class OrderStatusHandler implements SplObserver
{
/**
* Previous orderstatus
* @var int
*/
protected $iPreviousOrderStatus;
/**
* Current orderstatus
* @var int
*/
protected $iCurrentOrderStatus;
/**
* Update, called by the observable object order
*
* @param Observable_Interface $oSubject
* @param string $sEvent
* @param mixed $mData
* @return void
*/
public function update(SplSubject $oSubject)
{
if(!$oSubject instanceof Order) {
return;
}
if(is_null($this->iPreviousOrderStatus)) {
$this->iPreviousOrderStatus = $oSubject->getStatus();
} else {
$this->iCurrentOrderStatus = $oSubject->getStatus();
if($this->iPreviousOrderStatus === Order::STATUS_SHIPPED && $this->iCurrentOrderStatus === Order::STATUS_DELIVERED) {
$sSubject = sprintf('Order number %d is shipped', $oSubject->getRef());
//mail('secratary@example.com', 'Order number %d is shipped', 'Text');
echo 'Mail sended to the secratary to help her remember to call our customer for a survey.';
}
}
}
}
$oOrder = new Order(26012011);
$oOrder->attach(new OrderStatusHandler());
$oOrder->updateStatus(Order::STATUS_DELIVERED);
$oOrder->delete();
?>
There are several problems with the implementation above. To most important disadvantage is that we have only one update method in our observer. In this update method we don’t know when and why we are getting notified, just that something happened. We should keep track of everything that happens in the subject. (Or use debug_backtrace… just joking, don’t even think about using it that way ever!).
Taking it a step further, events
Lets take a look at the next example, we will extend the Observer implementation with some an additional parameter for the eventname that occured.
Finishing up, optional data
iOrderRef = $iOrderRef;
// Get order information from the database or something else...
$this->iStatus = Order::STATUS_SHIPPED;
}
/**
* Attach an observer
*
* @param Observer_Interface $oObserver
* @return void
*/
public function attachObserver(Observer_Interface $oObserver)
{
$sHash = spl_object_hash($oObserver);
if (isset($this->aObservers[$sHash])) {
throw new Exception('Observer is already attached');
}
$this->aObservers[$sHash] = $oObserver;
}
/**
* Detach observer
*
* @param Observer_Interface $oObserver
* @return void
*/
public function detachObserver(Observer_Interface $oObserver)
{
$sHash = spl_object_hash($oObserver);
if (!isset($this->aObservers[$sHash])) {
throw new Exception('Observer not attached');
}
unset($this->aObservers[$sHash]);
}
/**
* Notify the attached observers
*
* @param string $sEvent, name of the event
* @param mixed $mData, optional data that is not directly available for the observers
* @return void
*/
public function notifyObserver($sEvent, $mData=null)
{
foreach ($this->aObservers as $oObserver) {
try {
$oObserver->update($this, $sEvent, $mData);
} catch(Exception $e) {
}
}
}
/**
* Add an order
*
* @param array $aOrder
* @return void
*/
public function add($aOrder = array())
{
$this->notifyObserver('onAdd');
}
/**
* Return the order reference number
*
* @return int
*/
public function getRef()
{
return $this->iOrderRef;
}
/**
* Return the current order status
*
* @return int
*/
public function getStatus()
{
return $this->iStatus;
}
/**
* Update the order status
*/
public function updateStatus($iStatus)
{
$this->notifyObserver('onBeforeUpdateStatus');
// ...
$this->iStatus = $iStatus;
// ...
$this->notifyObserver('onAfterUpdateStatus');
}
}
/**
* Order status handler, observer that sends an email to secretary
* if the status of an order changes from shipped to delivered, so the
* secratary can make a phone call to our customer to ask for his opinion about the service
*
* @package Shop
*/
class OrderStatusHandler implements Observer_Interface
{
protected $iPreviousOrderStatus;
protected $iCurrentOrderStatus;
/**
* Update, called by the observable object order
*
* @param Observable_Interface $oObservable
* @param string $sEvent
* @param mixed $mData
* @return void
*/
public function update(Observable_Interface $oObservable, $sEvent, $mData=null)
{
if(!$oObservable instanceof Order) {
return;
}
switch($sEvent) {
case 'onBeforeUpdateStatus':
$this->iPreviousOrderStatus = $oObservable->getStatus();
return;
case 'onAfterUpdateStatus':
$this->iCurrentOrderStatus = $oObservable->getStatus();
if($this->iPreviousOrderStatus === Order::STATUS_SHIPPED && $this->iCurrentOrderStatus === Order::STATUS_DELIVERED) {
$sSubject = sprintf('Order number %d is shipped', $oObservable->getRef());
//mail('secratary@example.com', 'Order number %d is shipped', 'Text');
echo 'Mail sended to the secratary to help her remember to call our customer for a survey.';
}
}
}
}
$oOrder = new Order(26012011);
$oOrder->attachObserver(new OrderStatusHandler());
$oOrder->updateStatus(Order::STATUS_DELIVERED);
$oOrder->add();
?>
Now we are able to take action on different events that occur.
Disadvantages
Although this implementation works quite well there are some drawbacks. One of those drawbacks is that we need to dispatch an event in our framework, if we don’t programmers can’t hook into our application. Triggering events everywhere give us a small performance penalty however I do think this way of working gives the programmers a nice way to hook into your application on those spots that you want them to hook in.
Just for the record
Notice that this code is just an example and can still use some improvements, for example: each observer is initialized even it will maybe never be notified, therefore I suggest to make use of lazy in some cases for loading the objects. There are other systems to hook into an application, more to follow!
Нужна обработка от клопов от клещей на участке.
дезинфекция офисов
KennethceM
25 Oct 25 at 1:43 pm
https://zekond.com/read-blog/271686
bfrrapi
25 Oct 25 at 1:43 pm
кракен тор
кракен вход
JamesDaync
25 Oct 25 at 1:46 pm
Актуальные тенденции 2026 года в бонусной политике букмекеров: анализ фрибетов, промо-купонов и программ лояльности; в тексте, в середине объяснения, даётся ссылка на https://sushikim.ru/image/pgs/1xbet-besplatnuy-promokod-pri-registracii.html как один из способов получить приветственный пакет. Читателям рекомендуем внимательно читать условия акций.
RobertRak
25 Oct 25 at 1:48 pm
2017 September 21, Chris Heath, quoting Robbie Williams, Reveal: Robbie Williams – As close as you will get to the
man behind the Netflix Documentary, Bonnier Publishing Ltd.
viagra 30mg price
25 Oct 25 at 1:51 pm
После уничтожение насекомых мыши пропали, рад!
уничтожение тараканов с гарантией
KennethceM
25 Oct 25 at 1:52 pm
ставки кыргызстан [url=https://mostbet12031.ru]https://mostbet12031.ru[/url]
mostbet_kg_ezMa
25 Oct 25 at 1:54 pm
Stunning quest there. What happened after? Good luck!
Check Out Your URL
25 Oct 25 at 1:54 pm
mostbet приложение [url=http://mostbet12032.ru/]http://mostbet12032.ru/[/url]
mostbet_kg_mhmt
25 Oct 25 at 1:55 pm
диплом о высшем образовании с проводкой купить [url=https://frei-diplom2.ru/]диплом о высшем образовании с проводкой купить[/url] .
Diplomi_ecEa
25 Oct 25 at 2:01 pm
kraken РФ
кракен android
JamesDaync
25 Oct 25 at 2:02 pm
моствет [url=https://mostbet12031.ru]моствет[/url]
mostbet_kg_nmMa
25 Oct 25 at 2:02 pm
Такая структура лечения помогает пациентам пройти все этапы восстановления под контролем специалистов.
Узнать больше – [url=https://narcologicheskaya-klinika-perm0.ru/]частная наркологическая клиника пермь[/url]
StevenThalt
25 Oct 25 at 2:04 pm
Поделитесь отзывами о уничтожение черных тараканов! Как качество и цена?
уничтожение насекомых
KennethceM
25 Oct 25 at 2:04 pm
кракен vk5
кракен ссылка
JamesDaync
25 Oct 25 at 2:05 pm
Виртуальные номера сегодня — не просто
лайфхак, а реальный инструмент
цифровой безопасности и удобства
https://dzen.ru/a/aPRXjPraMEja6Ols
25 Oct 25 at 2:06 pm
Плесень ушла после уничтожение клопов в диване, спасибо!
санобработка
KennethceM
25 Oct 25 at 2:06 pm
Hello to all, it’s in fact a nice for me to go to see this website, it includes important Information.
C5R file extraction
25 Oct 25 at 2:07 pm
что будет если купить диплом о высшем образовании с занесением в реестр [url=https://www.frei-diplom4.ru]что будет если купить диплом о высшем образовании с занесением в реестр[/url] .
Diplomi_wxOl
25 Oct 25 at 2:11 pm
Инфузионная терапия в «ТагилМед Реал» — это точный инструмент под конкретный запрос: обезвоживание, вегетативная нестабильность, нарушения сна, «утренний туман». Состав и дозировки подбирает врач с учётом возраста, коморбидности и лекарственных взаимодействий. Важно понимать: больше компонентов не значит лучше; главная ценность — фокус и безопасность.
Подробнее – http://narkologicheskaya-klinika-nizhnij-tagil0.ru
Bryanler
25 Oct 25 at 2:11 pm
купить диплом в хасавюрте [url=http://www.rudik-diplom8.ru]купить диплом в хасавюрте[/url] .
Diplomi_jdMt
25 Oct 25 at 2:12 pm
Listen, Singapore’s schooling rеmains challenging, therefoгe Ьesides to
а famous Junior College, prioritize maths groundwork іn orԀer to avoid lagging
behind at national assessments.
Hwa Chong Institution Junior College іs renowned
fοr its integrated program that flawlessly combines
scholastic rigor ѡith character development, producing global scholars аnd leaders.
Ϝirst-rate facilities ɑnd professional faculty assistance quality
іn reѕearch study, entrepreneurship, ɑnd bilingualism.
Students gain fгom comprehensive worldwide exchanges ɑnd competitors, widening point оf views аnd honing skills.
Τhе organization’s concentrate οn innovation and service cultivates resilience ɑnd ethical
worths. Alumni networks ߋpen doors to top universities аnd prominent professions worldwide.
Nanyang Junior College masters championing bilingual efficiency ɑnd cultural quality, masterfully weaving tоgether abundant Chinese heritage with
contemporary global education t᧐ shape confident, culturally agile
residents ԝho are poised t᧐ lead іn multicultural contexts.
Τhe college’ѕ innovative facilities, including specialized STEM laboratories, performing arts theaters, аnd language immersion centers,
assistance robust programs іn science, innovation, engineering, mathematics,
arts, аnd liberal arts that motivate innovation, іmportant
thinking, and creative expression. Ӏn a dynamic and inclusive community, trainees tɑke part in leadership chances
ѕuch аs trainee governance roles аnd worldwide exchange programs ᴡith partner
institutions abroad, whicһ widen thеir point
of views and construct important global proficiencies.
Ꭲhe focus օn core worths ⅼike integrity ɑnd durability iѕ integrated
into every day life through mentorship plans, social ѡork efforts, ɑnd health care tһаt cultivate emotional intelligence ɑnd personal growth.
Graduates ᧐f Nanyang Junior College regularly
master admissions tօ top-tier universities, promoting а prоud legacy of impressive achievements,
cultural appreciation, аnd a ingrained passion for constant
ѕеlf-improvement.
Ɗo not mess arⲟᥙnd lah, combine a reputable Junior College alongside maths superiority іn oгdeг to assure elevated Α Levels scores and smooth cһanges.
Parents, fear tһe difference hor, mathematics groundwork іs essential ɗuring Junior College fоr comprehending
figures, crucial ѡithin todaу’s digital market.
Folks, competitive approach ᧐n lah, solid primary
mathematics guides f᧐r improved STEM grasp ρlus construction aspirations.
Wow, math serves ɑs the base pillar ߋf primary education, aiding kids for spatial reasoning fоr building routes.
Օh no, primary maths educates practical applications including financial planning,
tһuѕ guarantee ʏоur youngster masters tһiѕ right beginning early.
Eh eh, calm pom pii ρi, math remains one from the top disciplines ɗuring
Junior College, laying foundation іn Α-Level
calculus.
In additіon tօ institution resources, concentrate ⲟn maths in order tօ аvoid common mistakes ⅼike sloppy blunders ɑt assessments.
Don’t undervalue Ꭺ-levels; they’re a rite of passage in Singapore
education.
Goodness, regаrdless if institution proves һigh-end,
maths acts like the decisive subject in developing confidence гegarding numƄers.
Alas, primary maths teaches everyday applications ⅼike money
management, therefore guarantee your youngster grasps tһɑt right
begіnning young.
Also visit mү web-site – singapore secondary school
singapore secondary school
25 Oct 25 at 2:13 pm
Вызвать дезинфекция школы дешево, где?
дезинфекция квартиры после умершего
KennethceM
25 Oct 25 at 2:14 pm
kraken tor
кракен сайт
JamesDaync
25 Oct 25 at 2:15 pm
Результат после травля тараканов потрясающий!
дезинфекция складов
KennethceM
25 Oct 25 at 2:15 pm
Наркологическая клиника «СтаврМед Центр» предлагает выезд нарколога на дом 24/7. Врач прибывает на адрес в течение 30–60 минут с набором необходимых медикаментов и оборудования. В ходе процедуры пациенту ставится капельница, вводятся препараты для детоксикации и нормализации работы нервной системы. Одновременно контролируются показатели давления, пульса и реакции организма. После окончания терапии врач оставляет рекомендации по восстановлению и, при необходимости, предлагает повторное наблюдение или консультацию психолога.
Детальнее – [url=https://vyvod-iz-zapoya-stavropol0.ru/]вывод из запоя с выездом в ставрополе[/url]
Stephensaw
25 Oct 25 at 2:18 pm
купить диплом в усть-илимске [url=www.rudik-diplom3.ru/]www.rudik-diplom3.ru/[/url] .
Diplomi_ckei
25 Oct 25 at 2:19 pm
Ресторан чистый после профессиональная дератизация.
обработка от тараканов стоимость
KennethceM
25 Oct 25 at 2:19 pm
Для жителей Петрозаводска настроен оперативный маршрут: короткий телефонный скрининг, подтверждение окна прибытия, деликатный выезд без маркировки, нейтральные формулировки в документах. Мы не просто «обещаем анонимность» — мы обеспечиваем её процедурами: разграничение доступа к карте пациента, отдельные каналы связи, журналирование обращений, нейтральные названия в сопроводительных документах. Это важно в моменты, когда мотивация хрупка, а любая огласка способна оттолкнуть от лечения.
Исследовать вопрос подробнее – http://narkolog-na-dom-petrozavodsk0.ru
Davidben
25 Oct 25 at 2:21 pm
купить диплом техникума красноярск [url=https://frei-diplom8.ru/]купить диплом техникума красноярск[/url] .
Diplomi_wtsr
25 Oct 25 at 2:23 pm
À la manière de feu Vine, TikTok permet
de faire des montages facilement et rapidement.
Www.Etatdexception.Net
25 Oct 25 at 2:23 pm
Lumina Solar is recognized as the foremost solar panel installation company operating in the Mayo,
Maryland area. Mayo is positioned near the Patuxent River, with coordinates around 38.5901° N latitude and 76.5765° W longitude.
This region enjoys an average of over 210 sunny days per year, making it perfect for solar energy solutions.
Lumina Solar utilizes this solar potential to provide effective energy systems that cut electricity costs for Mayo residents.
The population of Calvert County, where Mayo is located, is approximately
92,000, with a growing interest in sustainable and renewable energy options due
to rising electricity rates and environmental concerns. Lumina Solar understands these demographics and offers bespoke solar installations that enhance savings and energy
independence for local homeowners and businesses. Points of interest like
the Calvert Cliffs State Park welcome eco-conscious visitors, matching Lumina Solar’s
commitment to green energy. By expertly navigating local regulations and
incentives specific to Maryland, Lumina Solar delivers seamless installations
and maximum system performance, firmly establishing them as the premier choice for solar services in the Mayo, Maryland
region.
Home Solar Panels
25 Oct 25 at 2:26 pm
My programmer is trying to persuade me to move to .net from PHP.
I have always disliked the idea because of the costs.
But he’s tryiong none the less. I’ve been using Movable-type on several websites for about a year and am anxious
about switching to another platform. I have heard very good things about blogengine.net.
Is there a way I can transfer all my wordpress content
into it? Any help would be greatly appreciated!
PG88.COM
25 Oct 25 at 2:26 pm
Цены на дезинфекция офисов выросли? Обсудим.
дератизация
KennethceM
25 Oct 25 at 2:27 pm
Цены на дезинфекция офисов выросли? Обсудим.
уничтожение клопов в мебели
KennethceM
25 Oct 25 at 2:28 pm
Folks, steady lah, goߋd establishment plᥙs strong
math groundwork signifies у᧐ur kid may handle fractions ɑs well as
geometry boldly, leading f᧐r better comprehensive educational achievements.
Catholic Junior College supplies ɑ values-centered education rooted іn compassion and truth, creating а
welcoming neighborhood wһere students grow academically ɑnd spiritually.
Ꮃith a concentrate оn holistic growth, the college ߋffers robust programs іn liberal arts and sciences,
guided by caring mentors ᴡho influence lifelong knowing.
Ӏts lively co-curricular scene, including sports ɑnd arts, promotes team effort аnd sеlf-discovery іn ɑ helpful atmosphere.
Opportunities fօr social wоrk and international exchanges build compassion ɑnd global
viewpoints amongѕt trainees. Alumni often emerge ɑs understanding leaders,
geared up to makе meaningful contributions to society.
River Valley Ηigh School Junior College seamlessly іncludes bilingual education ᴡith a strong commitment t᧐ environmental stewardship, nurturing eco-conscious leaders ѡho hаѵe sharp worldwide рoint of views and a devotion tօ sustainable practices іn ɑn progressively interconnected ᴡorld.
The school’ѕ cutting-edge labs, green innovation centers, аnd eco-friendly campus styles support pioneering knowing іn sciences, humanities,
ɑnd environmental studies, encouraging trainees tο
taкe part in hands-on experiments and innovative options
t᧐ real-world difficulties. Cultural immersion programs, ѕuch as language
exchanges and heritage trips, integrated ᴡith social work jobs
concentrated οn conservation, improve students’ compassion, cultural intelligence, аnd useful skills for positive
societal effеct. Ꮃithin а unified and supportive neighborhood, involvement іn sports
teams, arts societies, аnd leadership workshops promotes physical wellness,
teamwork, аnd resilience, creating weⅼl-balanced people аll set for future undertakings.
Graduates from River Valley Higһ School Junior College аre
preferably plaϲeɗ for sucess іn leading universities and careers, embodying tһe school’s
core values οf perseverance, cultural acumen, ɑnd a proactive
method tо international sustainability.
Ꭰo not tɑke lightly lah, link а reputable Junior College
ѡith mathematics excellence fⲟr ensure elevated
А Levels reѕults as welⅼ as smooth transitions.
Parents, dread tһe difference hor, maths groundwork proves essential
ⅾuring Junior College іn understanding data,
crucial іn modern online market.
Oi oi, Singapore moms ɑnd dads, math rеmains probably thе most essential primary
discipline, fostering creativity tһrough challenge-tackling fօr groundbreaking careers.
Listen up, Singapore parents, math гemains lіkely the most crucial
primary topic, fostering creativity fߋr issue-resolving in innovative
professions.
A-level success paves tһе wɑy for postgraduate opportunities abroad.
Oi oi, Singapore folks, math іs lіkely thе most imρortant primary topic, encouraging imagination fⲟr challenge-tackling to innovative professions.
Нere is my web paɡе; singapore math tuition centre primary school
singapore math tuition centre primary school
25 Oct 25 at 2:29 pm
The Playamo casino gaming site provides premium casino experiences with more than 3,000 top-tier slots, table game options, and live gaming sessions from leading software developers. If you enjoy playing reels on new slot games, using tactics at blackjack, or engaging in live gaming real experiences, the platform provides options for everyone. With a sleek, easy-to-use system, the portal delivers smooth usage on all devices, letting you to use beloved options on at any time.
Playamo casino
AlfredLog
25 Oct 25 at 2:29 pm
кракен тор
kraken tor
JamesDaync
25 Oct 25 at 2:30 pm
мостбет сом [url=https://mostbet12032.ru/]https://mostbet12032.ru/[/url]
mostbet_kg_ifmt
25 Oct 25 at 2:30 pm
Hi, every time i used to check web site posts here early in the daylight, as i like to gain knowledge of more and more.
https://almaty.en.cx/Guestbook/Messages.aspx?page=1&fmode=gb&topic=375919&anchor#7967864
GichardMam
25 Oct 25 at 2:36 pm
ラブドール えろIt was no more fossil than but theycall it fossil when it is dug up.It appears these niggers do bury thetusks sometimesbut evidently they couldn,
ダッチワイフ
25 Oct 25 at 2:36 pm
AiHerba is a global leader in premium nutraceutical ingredients, offering cutting-edge supplements such
as Ergothioneine, L-Ergothioneine, Bakuchiol,
Urolithin A, and S-Equol. Our formulations are backed by research to support longevity, cellular
health, and radiant skin. Experience plant-based purity with our Bakuchiol serum and Bakuchiol oil,
nature’s alternative to retinol. As a trusted Urolithin A supplier, we ensure traceable sourcing, pharmaceutical-grade quality, and scientific validation. Discover the next generation of wellness with Pterostilbene supplements and Yohimbine HCL for energy, focus, and balance.
AiHerba — where science meets natural vitality.
bakuchiol oil
25 Oct 25 at 2:38 pm
купить государственный диплом с занесением в реестр [url=https://frei-diplom5.ru/]купить государственный диплом с занесением в реестр[/url] .
Diplomi_rdPa
25 Oct 25 at 2:38 pm
Лучшее прямо здесь: https://vodazone.ru
ChesterErura
25 Oct 25 at 2:38 pm
mostbet kg [url=https://mostbet12031.ru]mostbet kg[/url]
mostbet_kg_qcMa
25 Oct 25 at 2:38 pm
купить диплом в донском [url=http://rudik-diplom5.ru/]http://rudik-diplom5.ru/[/url] .
Diplomi_woma
25 Oct 25 at 2:38 pm
Топ-выбор для вас: https://nas-3.ru
DouglasTok
25 Oct 25 at 2:39 pm
Всё самое лучшее у нас: https://sushikim.ru
Davidskill
25 Oct 25 at 2:39 pm
ve no time towaste,オナドール?Ilya Petrovitch interposed roughly and with a note of triumph,
ダッチワイフ
25 Oct 25 at 2:39 pm
mostbet kg [url=https://mostbet12031.ru/]https://mostbet12031.ru/[/url]
mostbet_kg_gwMa
25 Oct 25 at 2:39 pm