Skip to content

Commit

Permalink
Add DDM support
Browse files Browse the repository at this point in the history
  • Loading branch information
cleptric committed Nov 8, 2023
1 parent 29d198c commit 39e6638
Show file tree
Hide file tree
Showing 7 changed files with 182 additions and 0 deletions.
28 changes: 28 additions & 0 deletions src/Event.php
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,11 @@ final class Event
*/
private $checkIn;

/**
* @var array<string, array<string>|float|int|string>|null The check in data
*/
private $metric;

/**
* @var string|null The name of the server (e.g. the host name)
*/
Expand Down Expand Up @@ -210,6 +215,11 @@ public static function createCheckIn(?EventId $eventId = null): self
return new self($eventId, EventType::checkIn());
}

public static function createMetric(?EventId $eventId = null): self
{
return new self($eventId, EventType::metric());
}

/**
* Gets the ID of this event.
*/
Expand Down Expand Up @@ -354,6 +364,24 @@ public function setCheckIn(?CheckIn $checkIn): self
return $this;
}

/**
* @return array<string, array<string>|float|int|string>|null
*/
public function getMetric(): ?array
{
return $this->metric;
}

/**
* @param array<string, array<string>|float|int|string> $metric
*/
public function setMetric(array $metric): self
{
$this->metric = $metric;

return $this;
}

/**
* Gets the name of the server.
*/
Expand Down
5 changes: 5 additions & 0 deletions src/EventType.php
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,11 @@ public static function checkIn(): self
return self::getInstance('check_in');
}

public static function metric(): self
{
return self::getInstance('metric_buckets');
}

public function __toString(): string
{
return $this->value;
Expand Down
31 changes: 31 additions & 0 deletions src/Serializer/EnvelopItems/MetricsItem.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
<?php

declare(strict_types=1);

namespace Sentry\Serializer\EnvelopItems;

use Sentry\Event;
use Sentry\Util\JSON;

/**
* @internal
*/
class MetricsItem implements EnvelopeItemInterface
{
public static function toEnvelopeItem(Event $event): string
{
$header = [
'type' => (string) $event->getType(),
'content_type' => 'application/json',
];

$payload = [];

$metric = $event->getMetric();
if ($event->getMetric() !== null) {
$payload[] = $metric;
}

return sprintf("%s\n%s", JSON::encode($header), JSON::encode($payload));
}
}
4 changes: 4 additions & 0 deletions src/Serializer/PayloadSerializer.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
use Sentry\Options;
use Sentry\Serializer\EnvelopItems\CheckInItem;
use Sentry\Serializer\EnvelopItems\EventItem;
use Sentry\Serializer\EnvelopItems\MetricsItem;
use Sentry\Serializer\EnvelopItems\ProfileItem;
use Sentry\Serializer\EnvelopItems\TransactionItem;
use Sentry\Tracing\DynamicSamplingContext;
Expand Down Expand Up @@ -77,6 +78,9 @@ public function serialize(Event $event): string
case EventType::checkIn():
$items = CheckInItem::toEnvelopeItem($event);
break;
case EventType::metric():
$items = MetricsItem::toEnvelopeItem($event);
break;
}

return sprintf("%s\n%s", JSON::encode($envelopeHeader), $items);
Expand Down
78 changes: 78 additions & 0 deletions src/State/Hub.php
Original file line number Diff line number Diff line change
Expand Up @@ -319,6 +319,84 @@ public function getTransaction(): ?Transaction
return $this->getScope()->getTransaction();
}

/**
* @param int|float $value
* @param string[] $tags
*/
public function metricsIncr(string $name, $value, array $tags): ?EventId
{
$client = $this->getClient();

if ($client === null) {
return null;
}

$event = Event::createMetric();
$metric = [
'timestamp' => time(),
'width' => 0,
'name' => 'c:custom/' . $name . '@none',
'type' => 'c',
'value' => $value,
'tags' => $tags,
];
$event->setMetric($metric);

return $this->captureEvent($event);
}

/**
* @param int|float $value
* @param string[] $tags
*/
public function metricsDistribution(string $name, $value, array $tags, ?string $unit = null): ?EventId
{
$client = $this->getClient();

if ($client === null) {
return null;
}

$event = Event::createMetric();
$metric = [
'timestamp' => time(),
'width' => 0,
'name' => 'd:custom/' . $name . '@' . ($unit ?? 'none'),
'type' => 'd',
'value' => $value,
'tags' => $tags,
];
$event->setMetric($metric);

return $this->captureEvent($event);
}

/**
* @param int|float $value
* @param string[] $tags
*/
public function metricsSet(string $name, $value, array $tags): ?EventId
{
$client = $this->getClient();

if ($client === null) {
return null;
}

$event = Event::createMetric();
$metric = [
'timestamp' => time(),
'width' => 0,
'name' => 's:custom/' . $name . '@none',
'type' => 's',
'value' => $value,
'tags' => $tags,
];
$event->setMetric($metric);

return $this->captureEvent($event);
}

/**
* {@inheritdoc}
*/
Expand Down
9 changes: 9 additions & 0 deletions src/State/HubInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,15 @@
use Sentry\Tracing\Transaction;
use Sentry\Tracing\TransactionContext;

/**
* This interface represent the class which is responsible for maintaining a
* stack of pairs of clients and scopes. It is the main entry point to talk
* with the Sentry client.
*
* @method EventId|null metricsIncr(string $name, $value, array $tags)
* @method EventId|null metricsDistribution(string $name, $value, array $tags, ?string $unit = null)
* @method EventId|null metricsSet(string $name, $value, array $tags)
*/
interface HubInterface
{
/**
Expand Down
27 changes: 27 additions & 0 deletions src/functions.php
Original file line number Diff line number Diff line change
Expand Up @@ -268,3 +268,30 @@ function continueTrace(string $sentryTrace, string $baggage): TransactionContext

return TransactionContext::fromHeaders($sentryTrace, $baggage);
}

/**
* @param int|float $value
* @param string[] $tags
*/
function metricsIncr(string $key, $value, array $tags): ?EventId
{
return SentrySdk::getCurrentHub()->metricsIncr($key, $value, $tags);
}

/**
* @param int|float $value
* @param string[] $tags
*/
function metricsDistribution(string $key, $value, array $tags, ?string $unit = null): ?EventId
{
return SentrySdk::getCurrentHub()->metricsDistribution($key, $value, $tags, $unit);
}

/**
* @param int|float $value
* @param string[] $tags
*/
function metricsSet(string $key, $value, array $tags): ?EventId
{
return SentrySdk::getCurrentHub()->metricsSet($key, $value, $tags);
}

0 comments on commit 39e6638

Please sign in to comment.