drhttp / moesif-laravel
Moesif Collection/Data Ingestion Middleware for Laravel
Requires
- php: >=5.4.0
- ext-curl: *
- ext-json: *
- ext-mbstring: *
- apimatic/jsonmapper: ~1.0.0
- mashape/unirest-php: ~3.0.1
Requires (Dev)
- phpunit/phpunit: ~7.0
- dev-master
- 1.4.8
- 1.4.7
- 1.4.6
- 1.4.5
- 1.4.4
- 1.4.3
- v1.4.2
- 1.4.1
- 1.4.0
- 1.3.5
- 1.3.4
- 1.3.3
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.0
- 1.1.3
- 1.1.2
- 1.1.1
- 1.1.0
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- dev-refactor-ensure-valid-body
- dev-matthewoates-patch-1
- dev-add-IdentifyCompany-configuration
- dev-update-readme
- dev-feature-update-users
- dev-feature-transaction-id
- dev-fix-sampling-percentage
- dev-update-large-payload
- dev-feature-sampling-events
- dev-feature-update-user
This package is not auto-updated.
Last update: 2025-04-17 05:02:16 UTC
README
Middleware for PHP Laravel (> 5.1) to automatically log API Calls and sends to Moesif for API analytics and log analysis
Laravel 4.2
A Moesif SDK is available for Laravel 4.2. Credit for creating this goes to jonnypickett.
How to install
Via Composer
$ composer require moesif/moesif-laravel
or add 'moesif/moesif-laravel' to your composer.json file accordingly.
How to use
Add Service Provider
// In config/app.php
'providers' => [
/*
* Application Service Providers...
*/
Moesif\Middleware\MoesifLaravelServiceProvider::class,
];
Add to Middleware
If website root is your API, add to the root level:
// In App/Http/Kernel.php
protected $middleware = [
/*
* The application's global HTTP middleware stack.
*
* These middleware are run during every request to your application.
*/
\Moesif\Middleware\MoesifLaravel::class,
];
If API under specific route group, add to your route group:
// In App/Http/Kernel.php
protected $middlewareGroups = [
/**
* The application's API route middleware group.
*/
'api' => [
//
\Moesif\Middleware\MoesifLaravel::class,
],
];
To track only certain routes, use route specific middleware setup.
Publish the package config file
$ php artisan vendor:publish --provider="Moesif\Middleware\MoesifLaravelServiceProvider"
Setup config
Edit config/moesif.php
file.
// In config/moesif.php
return [
//
'applicationId' => 'Your Moesif Application Id',
'logBody' => true,
];
Your Moesif Application Id can be found in the Moesif Portal. After signing up for a Moesif account, your Moesif Application Id will be displayed during the onboarding steps.
You can always find your Moesif Application Id at any time by logging into the Moesif Portal, click on the top right menu, and then clicking Installation.
For other configuration options, see below.
Configuration options
You can define Moesif configuration options in the config/moesif.php
file. Some of these fields are functions.
applicationId
Type: String
Required, a string that identifies your application.
identifyUserId
Type: ($request, $response) => String
Optional, a function that takes a $request and $response and return a string for userId. Moesif automatically obtains end userId via $request->user()['id'], In case you use a non standard way of injecting user into $request or want to override userId, you can do so with identifyUserId.
// In config/moesif.php
$identifyUserId = function($request, $response) {
// Your custom code that returns a user id string
$user = $request->user();
if ($request->user()) {
return $user->id;
}
return NULL;
};
return [
//
'identifyUserId' => $identifyUserId
];
identifyCompanyId
Type: ($request, $response) => String
Optional, a function that takes a $request and $response and return a string for companyId.
// In config/moesif.php
$identifyCompanyId = function($request, $response) {
# Your custom code that returns a company id string
return '67890';
};
return [
//
'identifyCompanyId' => $identifyCompanyId
];
identifySessionId
Type: ($request, $response) => String
Optional, a function that takes a $request and $response and return a string for sessionId. Moesif automatically sessionizes by processing at your data, but you can override this via identifySessionId if you're not happy with the results.
getMetadata
Type: ($request, $response) => Associative Array
Optional, a function that takes a $request and $response and returns $metdata which is an associative array representation of JSON.
// In config/moesif.php
$getMetadata = function($request, $response) {
return array("foo"=>"laravel example", "boo"=>"custom data");
};
return [
//
'getMetadata' => $getMetadata
];
apiVersion
Type: String
Optional, a string to specifiy an API Version such as 1.0.1, allowing easier filters.
maskRequestHeaders
Type: $headers => $headers
Optional, a function that takes a $headers, which is an associative array, and
returns an associative array with your sensitive headers removed/masked.
// In config/moesif.php
$maskRequestHeaders = function($headers) {
$headers['password'] = '****';
return $headers;
};
return [
//
'maskRequestHeaders' => $maskRequestHeaders
];
maskRequestBody
Type: $body => $body
Optional, a function that takes a $body, which is an associative array representation of JSON, and
returns an associative array with any information removed.
// In config/moesif.php
$maskRequestBody = function($body) {
// remove any sensitive information.
$body['password'] = '****';
return $body;
};
return [
//
'maskRequestBody' => $maskRequestBody
];
maskResponseHeaders
Type: $headers => $headers
Optional, same as above, but for Responses.
maskResponseBody
Type: $body => $body
Optional, same as above, but for Responses.
skip
Type: ($request, $response) => String
Optional, a function that takes a $request and $response and returns true if
this API call should be not be sent to Moesif.
debug
Type: Boolean
Optional, If true, will print debug messages using Illuminate\Support\Facades\Log
logBody
Type: Boolean
Optional, Default true, Set to false to remove logging request and response body to Moesif.
Update a Single User
Create or update a user profile in Moesif.
The metadata field can be any customer demographic or other info you want to store.
Only the user_id
field is required.
use Moesif\Middleware\MoesifLaravel;
// Only userId is required.
// Campaign object is optional, but useful if you want to track ROI of acquisition channels
// See https://www.moesif.com/docs/api#users for campaign schema
// metadata can be any custom object
$user = array(
"user_id" => "12345",
"company_id" => "67890", // If set, associate user with a company object
"campaign" => array(
"utm_source" => "google",
"utm_medium" => "cpc",
"utm_campaign" => "adwords",
"utm_term" => "api+tooling",
"utm_content" => "landing"
),
"metadata" => array(
"email" => "john@acmeinc.com",
"first_name" => "John",
"last_name" => "Doe",
"title" => "Software Engineer",
"sales_info" => array(
"stage" => "Customer",
"lifetime_value" => 24000,
"account_owner" => "mary@contoso.com"
)
)
);
$middleware = new MoesifLaravel();
$middleware->updateUser($user);
The metadata
field can be any custom data you want to set on the user. The user_id
field is required.
Update Users in Batch
Similar to updateUser, but used to update a list of users in one batch.
Only the user_id
field is required.
use Moesif\Middleware\MoesifLaravel;
$userA = array(
"user_id" => "12345",
"company_id" => "67890", // If set, associate user with a company object
"campaign" => array(
"utm_source" => "google",
"utm_medium" => "cpc",
"utm_campaign" => "adwords",
"utm_term" => "api+tooling",
"utm_content" => "landing"
),
"metadata" => array(
"email" => "john@acmeinc.com",
"first_name" => "John",
"last_name" => "Doe",
"title" => "Software Engineer",
"sales_info" => array(
"stage" => "Customer",
"lifetime_value" => 24000,
"account_owner" => "mary@contoso.com"
)
)
);
$userB = array(
"user_id" => "12345",
"company_id" => "67890", // If set, associate user with a company object
"campaign" => array(
"utm_source" => "google",
"utm_medium" => "cpc",
"utm_campaign" => "adwords",
"utm_term" => "api+tooling",
"utm_content" => "landing"
),
"metadata" => array(
"email" => "john@acmeinc.com",
"first_name" => "John",
"last_name" => "Doe",
"title" => "Software Engineer",
"sales_info" => array(
"stage" => "Customer",
"lifetime_value" => 24000,
"account_owner" => "mary@contoso.com"
)
)
);
$users = array($userA);
$middleware = new MoesifLaravel();
$middleware->updateUsersBatch($users);
The metadata
field can be any custom data you want to set on the user. The user_id
field is required.
Update a Single Company
Create or update a company profile in Moesif.
The metadata field can be any company demographic or other info you want to store.
Only the company_id
field is required.
use Moesif\Middleware\MoesifLaravel;
// Only companyId is required.
// Campaign object is optional, but useful if you want to track ROI of acquisition channels
// See https://www.moesif.com/docs/api#update-a-company for campaign schema
// metadata can be any custom object
$company = array(
"company_id" => "67890",
"company_domain" => "acmeinc.com", // If domain is set, Moesif will enrich your profiles with publicly available info
"campaign" => array(
"utm_source" => "google",
"utm_medium" => "cpc",
"utm_campaign" => "adwords",
"utm_term" => "api+tooling",
"utm_content" => "landing"
),
"metadata" => array(
"org_name" => "Acme, Inc",
"plan_name" => "Free",
"deal_stage" => "Lead",
"mrr" => 24000,
"demographics" => array(
"alexa_ranking" => 500000,
"employee_count" => 47
)
)
);
$middleware = new MoesifLaravel();
$middleware->updateCompany($company);
The metadata
field can be any custom data you want to set on the company. The company_id
field is required.
Update Companies in Batch
Similar to update_company, but used to update a list of companies in one batch.
Only the company_id
field is required.
use Moesif\Middleware\MoesifLaravel;
$companyA = array(
"company_id" => "67890",
"company_domain" => "acmeinc.com", // If domain is set, Moesif will enrich your profiles with publicly available info
"campaign" => array(
"utm_source" => "google",
"utm_medium" => "cpc",
"utm_campaign" => "adwords",
"utm_term" => "api+tooling",
"utm_content" => "landing"
),
"metadata" => array(
"org_name" => "Acme, Inc",
"plan_name" => "Free",
"deal_stage" => "Lead",
"mrr" => 24000,
"demographics" => array(
"alexa_ranking" => 500000,
"employee_count" => 47
)
)
);
$companies = array($companyA);
$middleware = new MoesifLaravel();
$middleware->updateCompaniesBatch($companies);
The metadata
field can be any custom data you want to set on the company. The company_id
field is required.
Credits for Moesif Laravel SDK
- Parts of queuing & sending data via forked non-blocking process is based on Mixpanel's PHP client code which is open sourced under Apache License, Version 2.0.
Additional Tips:
- The forked (i.e. non-blocking way) of sending data is using exec() with a cURL command. The Php exec() command can be successful but the cURL itself may have 401 errors. So after integration, if you don't see events and data show up in your Moesif Dash. Please turn on debug option, then the cURL command itself will logged. You can execute that cURL command and see what the issues are. The most common thing to check is if the Application ID is set correctly.
Test Laravel App with Moesif Integrated
An Example Laravel App with Moesif Integrated
Other integrations
To view more documentation on integration options, please visit the Integration Options Documentation.