Initial commit: CloudOps infrastructure platform

This commit is contained in:
root
2026-04-09 19:58:57 +02:00
commit 1166a52f26
7762 changed files with 839452 additions and 0 deletions

View File

@@ -0,0 +1,26 @@
# Workflow name:
name: Close Pull Requests
# Workflow triggers:
on:
pull_request_target:
types: [opened]
# Workflow jobs:
jobs:
run:
runs-on: ubuntu-latest
steps:
- uses: superbrothers/close-pull-request@v3
with:
comment: |
Thank you for submitting a pull request. :raised_hands:
We greatly appreciate your willingness to submit a contribution. However, we are not accepting pull requests against this repository, as all development happens on the [main project repository](https://github.com/mautic/mautic).
We kindly request that you submit this pull request against the [respective directory](https://github.com/mautic/mautic/blob/head/app/) of the main repository where we'll review and provide feedback. If this is your first Mautic contribution, be sure to read the [contributing guide](https://github.com/mautic/mautic/blob/head/.github/CONTRIBUTING.md) which provides guidelines and instructions for submitting contributions.
Thank you again, and we look forward to receiving your contribution! :smiley:
Best,
The Mautic team

View File

@@ -0,0 +1 @@
deny from all

View File

@@ -0,0 +1,351 @@
<?php
use Mautic\CoreBundle\Loader\ParameterLoader;
use Mautic\CoreBundle\Release\ThisRelease;
use Symfony\Component\Config\Loader\LoaderInterface;
use Symfony\Component\DependencyInjection\ContainerBuilder;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpKernel\HttpKernelInterface;
use Symfony\Component\HttpKernel\Kernel;
/**
* Mautic Application Kernel.
*/
class AppKernel extends Kernel
{
/**
* @var bool|null
*/
private $installed;
/**
* @var ParameterLoader|null
*/
private $parameterLoader;
/**
* @var string
*/
private $projectDir;
/**
* @param string $environment The environment
* @param bool $debug Whether to enable debugging or not
*
* @api
*/
public function __construct($environment, $debug)
{
$metadata = ThisRelease::getMetadata();
defined('MAUTIC_ENV') or define('MAUTIC_ENV', $environment);
defined('MAUTIC_VERSION') or define('MAUTIC_VERSION', $metadata->getVersion());
/**
* This is required for Doctrine's automatic database detection. When Mautic hasn't been
* installed yet, we don't have a database to connect to, causing automatic database platform
* detection to fail. We use the MAUTIC_DB_SERVER_VERSION constant to temporarily set a server_version
* if no database settings have been provided yet.
*/
if (!defined('MAUTIC_DB_SERVER_VERSION')) {
$localConfigFile = ParameterLoader::getLocalConfigFile($this->getApplicationDir().'/app', false);
define('MAUTIC_DB_SERVER_VERSION', file_exists($localConfigFile) ? null : '8.4');
}
parent::__construct($environment, $debug);
}
public function handle(Request $request, $type = HttpKernelInterface::MAIN_REQUEST, $catch = true): Response
{
if (false !== strpos($request->getRequestUri(), 'installer') || !$this->isInstalled()) {
defined('MAUTIC_INSTALLER') or define('MAUTIC_INSTALLER', 1);
}
if (defined('MAUTIC_INSTALLER')) {
$uri = $request->getRequestUri();
if (false === strpos($uri, 'installer')) {
$base = $request->getBaseUrl();
$prefix = '';
// check to see if the .htaccess file exists or if not running under apache
if (false === stripos($request->server->get('SERVER_SOFTWARE', ''), 'apache')
|| !file_exists($this->getProjectDir().'/.htaccess')
&& false === strpos(
$base,
'index'
)
) {
$prefix .= '/index.php';
}
return new RedirectResponse($request->getUriForPath($prefix.'/installer'));
}
}
if (false === $this->booted) {
$this->boot();
}
// Check for an an active db connection and die with error if unable to connect
if (!defined('MAUTIC_INSTALLER')) {
$db = $this->getContainer()->get('database_connection');
try {
$db->connect();
} catch (Exception $e) {
error_log($e);
throw new Mautic\CoreBundle\Exception\DatabaseConnectionException($this->getContainer()->get('translator')->trans('mautic.core.db.connection.error', ['%code%' => $e->getCode()]), 0, $e);
}
}
return parent::handle($request, $type, $catch);
}
public function registerBundles(): iterable
{
$bundles = [
// Symfony/Core Bundles
new Symfony\Bundle\FrameworkBundle\FrameworkBundle(),
new Symfony\Bundle\SecurityBundle\SecurityBundle(),
new Symfony\Bundle\MonologBundle\MonologBundle(),
new Doctrine\Bundle\DoctrineBundle\DoctrineBundle(),
new Doctrine\Bundle\FixturesBundle\DoctrineFixturesBundle(),
new Doctrine\Bundle\MigrationsBundle\DoctrineMigrationsBundle(),
new Knp\Bundle\MenuBundle\KnpMenuBundle(),
new FOS\OAuthServerBundle\FOSOAuthServerBundle(),
new FOS\RestBundle\FOSRestBundle(),
new JMS\SerializerBundle\JMSSerializerBundle(),
new Oneup\UploaderBundle\OneupUploaderBundle(),
new Symfony\Bundle\TwigBundle\TwigBundle(),
new LightSaml\SymfonyBridgeBundle\LightSamlSymfonyBridgeBundle(),
new LightSaml\SpBundle\LightSamlSpBundle(),
new FM\ElfinderBundle\FMElfinderBundle(),
new Exercise\HTMLPurifierBundle\ExerciseHTMLPurifierBundle(),
new ApiPlatform\Symfony\Bundle\ApiPlatformBundle(),
// Mautic Bundles
new Mautic\ApiBundle\MauticApiBundle(),
new Mautic\AssetBundle\MauticAssetBundle(),
new Mautic\CampaignBundle\MauticCampaignBundle(),
new Mautic\CategoryBundle\MauticCategoryBundle(),
new Mautic\ChannelBundle\MauticChannelBundle(),
new Mautic\ConfigBundle\MauticConfigBundle(),
new Mautic\CoreBundle\MauticCoreBundle(),
new Mautic\DashboardBundle\MauticDashboardBundle(),
new Mautic\DynamicContentBundle\MauticDynamicContentBundle(),
new Mautic\EmailBundle\MauticEmailBundle(),
new Mautic\FormBundle\MauticFormBundle(),
new Mautic\InstallBundle\MauticInstallBundle(),
new Mautic\IntegrationsBundle\IntegrationsBundle(),
new Mautic\LeadBundle\MauticLeadBundle(),
new Mautic\MarketplaceBundle\MarketplaceBundle(),
new Mautic\MessengerBundle\MauticMessengerBundle(),
new Mautic\NotificationBundle\MauticNotificationBundle(),
new Mautic\PageBundle\MauticPageBundle(),
new Mautic\PluginBundle\MauticPluginBundle(),
new Mautic\PointBundle\MauticPointBundle(),
new Mautic\ProjectBundle\MauticProjectBundle(),
new Mautic\ReportBundle\MauticReportBundle(),
new Mautic\SmsBundle\MauticSmsBundle(),
new Mautic\StageBundle\MauticStageBundle(),
new Mautic\StatsBundle\MauticStatsBundle(),
new Mautic\UserBundle\MauticUserBundle(),
new Mautic\WebhookBundle\MauticWebhookBundle(),
new Mautic\CacheBundle\MauticCacheBundle(),
];
// dynamically register Mautic Plugin Bundles
$searchPath = $this->getApplicationDir().'/plugins';
$finder = new Symfony\Component\Finder\Finder();
$finder->files()
->followLinks()
->depth('1')
->in($searchPath)
->name('*Bundle.php');
foreach ($finder as $file) {
$dirname = basename($file->getRelativePath());
$filename = substr($file->getFilename(), 0, -4);
$class = '\\MauticPlugin\\'.$dirname.'\\'.$filename;
if (class_exists($class)) {
$plugin = new $class();
if ($plugin instanceof Symfony\Component\HttpKernel\Bundle\Bundle) {
if (defined($class.'::MINIMUM_MAUTIC_VERSION')) {
// Check if this version supports the plugin before loading it
if (version_compare($this->getVersion(), constant($class.'::MINIMUM_MAUTIC_VERSION'), 'lt')) {
continue;
}
}
$bundles[] = $plugin;
}
unset($plugin);
}
}
if (in_array($this->getEnvironment(), ['dev', 'test'])) {
$bundles[] = new Symfony\Bundle\WebProfilerBundle\WebProfilerBundle();
$bundles[] = new Symfony\Bundle\MakerBundle\MakerBundle();
}
if (in_array($this->getEnvironment(), ['test'])) {
$bundles[] = new Liip\FunctionalTestBundle\LiipFunctionalTestBundle();
$bundles[] = new Liip\TestFixturesBundle\LiipTestFixturesBundle();
}
// Check for local bundle inclusion
if (file_exists($this->getProjectDir().'/config/bundles_local.php')) {
include $this->getProjectDir().'/config/bundles_local.php';
}
return $bundles;
}
protected function build(ContainerBuilder $container): void
{
$container->registerForAutoconfiguration(Mautic\CoreBundle\Model\MauticModelInterface::class)
->addTag(Mautic\CoreBundle\DependencyInjection\Compiler\ModelPass::TAG);
}
public function boot(): void
{
if (true === $this->booted) {
return;
}
// load parameters with defaults into the environment
$parameterLoader = $this->getParameterLoader();
$parameterLoader->loadIntoEnvironment();
if (!defined('MAUTIC_TABLE_PREFIX')) {
// Set the table prefix before boot.
// Firstly look into environment variables.
$prefix = $_SERVER['MAUTIC_TABLE_PREFIX'];
// Secondly look into the local.php file.
if (empty($prefix)) {
$prefix = $parameterLoader->getLocalParameterBag()->get('db_table_prefix', '');
}
define('MAUTIC_TABLE_PREFIX', $prefix);
}
// init bundles
$this->initializeBundles();
// init container
$this->initializeContainer();
// boot bundles
foreach ($this->getBundles() as $name => $bundle) {
$bundle->setContainer($this->container);
$bundle->boot();
}
$this->booted = true;
}
protected function prepareContainer(ContainerBuilder $container): void
{
$container->setParameter('mautic.application_dir', $this->getApplicationDir());
parent::prepareContainer($container);
}
public function registerContainerConfiguration(LoaderInterface $loader): void
{
$loader->load($this->getApplicationDir().'/app/config/config_'.$this->getEnvironment().'.php');
}
/**
* Retrieves the application's version number.
*/
public function getVersion(): string
{
return MAUTIC_VERSION;
}
/**
* Checks if the application has been installed.
*/
protected function isInstalled(): bool
{
if (null === $this->installed) {
$localParameters = $this->getParameterLoader()->getLocalParameterBag();
$dbDriver = $localParameters->get('db_driver');
$siteUrl = $localParameters->get('site_url');
$this->installed = !empty($dbDriver) && !empty($siteUrl);
}
return $this->installed;
}
public function getApplicationDir(): string
{
return dirname(__DIR__);
}
public function getProjectDir(): string
{
if (null === $this->projectDir) {
$r = new ReflectionObject($this);
if (!is_file($dir = $r->getFileName())) {
throw new LogicException(sprintf('Cannot auto-detect project dir for kernel of class "%s".', $r->name));
}
// We need 1 level deeper than the parent method, as the app folder contains a composer.json file
$dir = $rootDir = \dirname($dir, 2);
while (!is_file($dir.'/composer.json')) {
if ($dir === \dirname($dir)) {
return $this->projectDir = $rootDir;
}
$dir = \dirname($dir);
}
$this->projectDir = $dir;
}
return $this->projectDir;
}
/**
* @api
*/
public function getCacheDir(): string
{
if ($cachePath = $this->getParameterLoader()->getLocalParameterBag()->get('cache_path')) {
$envFolder = ('/' != substr($cachePath, -1)) ? '/'.$this->environment : $this->environment;
return str_replace('%kernel.project_dir%', $this->getProjectDir(), $cachePath.$envFolder);
}
return $this->getProjectDir().'/var/cache/'.$this->getEnvironment();
}
public function getLogDir(): string
{
if ($logPath = $this->getParameterLoader()->getLocalParameterBag()->get('log_path')) {
return str_replace('%kernel.project_dir%', $this->getProjectDir(), $logPath);
}
return $this->getProjectDir().'/var/logs';
}
/**
* Get local config file.
*/
public function getLocalConfigFile(): string
{
return ParameterLoader::getLocalConfigFile($this->getApplicationDir().'/app');
}
private function getParameterLoader(): ParameterLoader
{
if ($this->parameterLoader) {
return $this->parameterLoader;
}
return $this->parameterLoader = new ParameterLoader();
}
}

View File

@@ -0,0 +1,57 @@
<?php
declare(strict_types=1);
use Symfony\Component\DependencyInjection\ContainerInterface;
class AppTestKernel extends AppKernel
{
private bool $isTestContainerSet = false;
/**
* {@inheritdoc}
*/
protected function isInstalled(): bool
{
return true;
}
public function getCacheDir(): string
{
if ($dir = getenv('TEST_CACHE_DIR')) {
return dirname(__DIR__).'/'.$dir;
}
return parent::getCacheDir();
}
public function getLogDir(): string
{
if ($dir = getenv('TEST_LOG_DIR')) {
return dirname(__DIR__).'/'.$dir;
}
return parent::getLogDir();
}
/**
* @throws Exception
*/
public function getContainer(): ContainerInterface
{
if (!$this->container) {
$this->boot();
}
if ($this->isTestContainerSet) {
return $this->container;
}
$this->isTestContainerSet = true;
$testContainer = $this->container->get('test.service_container');
$testContainer->setPublicContainer($this->container);
return $this->container;
}
}

View File

@@ -0,0 +1,5 @@
# Mautic Core-lib repo
## This is a mirror repository of the /app folder of Mautic, and is managed centrally in https://github.com/mautic/mautic/blob/head/app. This is a read-only mirror repository.
**📣 Please make PRs and issues against the [mautic/mautic](https://github.com/mautic/mautic) repository, not here!**

View File

@@ -0,0 +1 @@
allow from all

View File

@@ -0,0 +1,172 @@
/* Modal Base CSS */
.mauticForm-overlay
{
position: fixed;
z-index: 9998;
top: 0;
left: 0;
opacity: 0;
width: 100%;
height: 100%;
-webkit-transition: 1ms opacity ease;
-moz-transition: 1ms opacity ease;
-ms-transition: 1ms opacity ease;
-o-transition: 1ms opacity ease;
transition: 1ms opacity ease;
background: rgba(0,0,0,.6);
}
.mauticForm-modal
{
position: absolute;
z-index: 9999;
top: 50%;
left: 50%;
opacity: 0;
width: 94%;
padding: 24px 20px;
-webkit-transition: 1ms opacity ease;
-moz-transition: 1ms opacity ease;
-ms-transition: 1ms opacity ease;
-o-transition: 1ms opacity ease;
transition: 1ms opacity ease;
-webkit-transform: translate(-50%, -50%);
-moz-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
-o-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
border-radius: 2px;
background: #fff;
}
.mauticForm-modal.mauticForm-open.mauticForm-anchored
{
top: 20px;
-webkit-transform: translate(-50%, 0);
-moz-transform: translate(-50%, 0);
-ms-transform: translate(-50%, 0);
-o-transform: translate(-50%, 0);
transform: translate(-50%, 0);
}
.mauticForm-modal.mauticForm-open
{
opacity: 1;
}
.mauticForm-overlay.mauticForm-open
{
opacity: 1;
}
/* Close Button */
.mauticForm-close
{
font-family: Helvetica,Arial,sans-serif;
font-size: 24px;
font-weight: 700;
line-height: 12px;
position: absolute;
top: 5px;
right: 5px;
padding: 5px 7px 7px;
cursor: pointer;
color: #fff;
border: 0;
outline: none;
background: #e74c3c;
}
.mauticForm-close:hover
{
background: #c0392b;
}
/* Default Animation */
.mauticForm-overlay.fade-and-drop
{
display: block;
opacity: 0;
}
.mauticForm-modal.fade-and-drop
{
top: -300%;
opacity: 1;
display: block;
}
.mauticForm-modal.fade-and-drop.mauticForm-open
{
top: 50%;
-webkit-transition: 500ms top 500ms ease;
-moz-transition: 500ms top 500ms ease;
-ms-transition: 500ms top 500ms ease;
-o-transition: 500ms top 500ms ease;
transition: 500ms top 500ms ease;
}
.mauticForm-modal.fade-and-drop.mauticForm-open.mauticForm-anchored
{
-webkit-transition: 500ms top 500ms ease;
-moz-transition: 500ms top 500ms ease;
-ms-transition: 500ms top 500ms ease;
-o-transition: 500ms top 500ms ease;
transition: 500ms top 500ms ease;
}
.mauticForm-overlay.fade-and-drop.mauticForm-open
{
top: 0;
-webkit-transition: 500ms opacity ease;
-moz-transition: 500ms opacity ease;
-ms-transition: 500ms opacity ease;
-o-transition: 500ms opacity ease;
transition: 500ms opacity ease;
opacity: 1;
}
.mauticForm-modal.fade-and-drop
{
-webkit-transition: 500ms top ease;
-moz-transition: 500ms top ease;
-ms-transition: 500ms top ease;
-o-transition: 500ms top ease;
transition: 500ms top ease;
}
.mauticForm-overlay.fade-and-drop
{
-webkit-transition: 500ms opacity 500ms ease;
-moz-transition: 500ms opacity 500ms ease;
-ms-transition: 500ms opacity 500ms ease;
-o-transition: 500ms opacity 500ms ease;
transition: 500ms opacity 500ms ease;
}
.mauticForm-content {
height: 100%;
}

View File

@@ -0,0 +1,140 @@
{
"name": "Engagement",
"description": "Start with a dashboard of 13 widgets that provide insights into lead generation, engagement, email interactions, and contact management.",
"widgets": [
{
"name": "Contacts created",
"width": 100,
"height": 330,
"ordering": 0,
"type": "created.leads.in.time",
"params": {
"lists": "identifiedVsAnonymous",
"flag": null
},
"template": null
},
{
"name": "Visits",
"width": 50,
"height": 330,
"ordering": 1,
"type": "page.hits.in.time",
"params": {
"flag": null
},
"template": null
},
{
"name": "Contact map",
"width": 50,
"height": 330,
"ordering": 3,
"type": "map.of.leads",
"params": [
],
"template": null
},
{
"name": "Emails sent \/ opened",
"width": 50,
"height": 330,
"ordering": 5,
"type": "emails.in.time",
"params": {
"flag": null
},
"template": null
},
{
"name": "Points",
"width": 50,
"height": 330,
"ordering": 6,
"type": "points.in.time",
"params": [
],
"template": null
},
{
"name": "Unique\/returning visitors",
"width": 25,
"height": 330,
"ordering": 7,
"type": "unique.vs.returning.leads",
"params": [
],
"template": null
},
{
"name": "Identified vs anonymous leads",
"width": 25,
"height": 330,
"ordering": 8,
"type": "anonymous.vs.identified.leads",
"params": [
],
"template": null
},
{
"name": "Ignored\/opened emails",
"width": 25,
"height": 330,
"ordering": 9,
"type": "ignored.vs.read.emails",
"params": [
],
"template": null
},
{
"name": "Upcoming Emails",
"width": 25,
"height": 330,
"ordering": 10,
"type": "upcoming.emails",
"params": [
],
"template": null
},
{
"name": "Top Contact Creators",
"width": 100,
"height": 330,
"ordering": 11,
"type": "top.creators",
"params": [
],
"template": null
},
{
"name": "Dwell times",
"width": 25,
"height": 330,
"ordering": 12,
"type": "dwell.times",
"params": [
],
"template": null
},
{
"name": "Recent activity",
"width": 50,
"height": 330,
"ordering": 13,
"type": "recent.activity",
"params": [
],
"template": null
},
{
"name": "Top lists",
"width": 25,
"height": 330,
"ordering": 14,
"type": "top.lists",
"params": [
],
"template": null
}
]
}

View File

@@ -0,0 +1,48 @@
{
"name": "Default",
"description": "Start with a dashboard of 5 widgets that provide an overview of your marketing activities and performance metrics.",
"widgets":
[
{
"name": "Contacts Created",
"width": 100,
"height": 330,
"ordering": 0,
"type": "created.leads.in.time",
"params": {
"lists": "identifiedVsAnonymous"
}
},
{
"name": "Page Visits",
"width": 50,
"height": 330,
"ordering": 1,
"type": "page.hits.in.time",
"params": {
"flag": "unique"
}
},
{
"name": "Form Submissions",
"width": 50,
"height": 330,
"ordering": 2,
"type": "submissions.in.time"
},
{
"name": "Recent Activity",
"width": 50,
"height": 330,
"ordering": 3,
"type": "recent.activity"
},
{
"name": "Upcoming Emails",
"width": 50,
"height": 330,
"ordering": 4,
"type": "upcoming.emails"
}
]
}

View File

@@ -0,0 +1,74 @@
{
"name": "Example - Email Overview",
"description": "Start with a dashboard of 7 widgets that provide insights into email interactions and contact management.",
"widgets": [
{
"name": "Emails sent \/ opened",
"width": 100,
"height": 330,
"ordering": 0,
"type": "emails.in.time",
"params": {
"flag": "sent_and_opened"
},
"template": null
},
{
"name": "Upcoming emails",
"width": 25,
"height": 330,
"ordering": 1,
"type": "upcoming.emails",
"params": [],
"template": null
},
{
"name": "Ignored\/opened emails",
"width": 25,
"height": 330,
"ordering": 2,
"type": "ignored.vs.read.emails",
"params": [],
"template": null
},
{
"name": "Most sent emails",
"width": 25,
"height": 330,
"ordering": 3,
"type": "most.sent.emails",
"params": [],
"template": null
},
{
"name": "Most read emails",
"width": 25,
"height": 330,
"ordering": 4,
"type": "most.read.emails",
"params": [],
"template": null
},
{
"name": "Contact map",
"width": 50,
"height": 330,
"ordering": 5,
"type": "map.of.leads",
"params": [],
"template": null
},
{
"name": "Contacts created",
"width": 50,
"height": 330,
"ordering": 6,
"type": "created.leads.in.time",
"params": {
"lists": "identifiedVsAnonymous",
"flag": null
},
"template": null
}
]
}

View File

@@ -0,0 +1,138 @@
{
"name": "Forms and Assets",
"description": "Start with a dashboard of 14 widgets that help you to check form submissions and identified contacts.",
"widgets": [
{
"name": "Contacts Created",
"width": 100,
"height": 330,
"ordering": 0,
"type": "created.leads.in.time",
"params": {
"lists": "identifiedVsAnonymous"
},
"template": null
},
{
"name": "Created contacts in time",
"width": 100,
"height": 215,
"ordering": 0,
"type": "created.leads.in.time",
"params": {
"flag": "identified"
},
"template": null
},
{
"name": "Page Visits",
"width": 50,
"height": 330,
"ordering": 1,
"type": "page.hits.in.time",
"params": {
"flag": "unique"
},
"template": null
},
{
"name": "Top segments",
"width": 50,
"height": 215,
"ordering": 1,
"type": "top.lists",
"params": [],
"template": null
},
{
"name": "Created contacts",
"width": 50,
"height": 215,
"ordering": 2,
"type": "created.leads",
"params": [],
"template": null
},
{
"name": "Form Submissions",
"width": 50,
"height": 330,
"ordering": 3,
"type": "submissions.in.time",
"params": [],
"template": null
},
{
"name": "Recent Activity",
"width": 50,
"height": 330,
"ordering": 3,
"type": "recent.activity",
"params": [],
"template": null
},
{
"name": "Upcoming Emails",
"width": 50,
"height": 330,
"ordering": 4,
"type": "upcoming.emails",
"params": [],
"template": null
},
{
"name": "Top submission referrers",
"width": 25,
"height": 330,
"ordering": 4,
"type": "top.submission.referrers",
"params": [],
"template": null
},
{
"name": "Created forms",
"width": 25,
"height": 330,
"ordering": 5,
"type": "created.forms",
"params": [],
"template": null
},
{
"name": "Downloads in time",
"width": 25,
"height": 330,
"ordering": 6,
"type": "asset.downloads.in.time",
"params": [],
"template": null
},
{
"name": "Popular assets",
"width": 25,
"height": 330,
"ordering": 7,
"type": "popular.assets",
"params": [],
"template": null
},
{
"name": "Unique vs repetitive downloads",
"width": 25,
"height": 330,
"ordering": 8,
"type": "unique.vs.repetitive.downloads",
"params": [],
"template": null
},
{
"name": "Created assets",
"width": 25,
"height": 330,
"ordering": 9,
"type": "created.assets",
"params": [],
"template": null
}
]
}

View File

@@ -0,0 +1,109 @@
{
"name": "Landing pages",
"description": "Start with a dashboard of 11 widgets that provide insights related to landing pages and interactions.",
"widgets": [
{
"name": "Contacts Created",
"width": 100,
"height": 215,
"ordering": 0,
"type": "created.leads.in.time",
"params": {
"lists": "identifiedVsAnonymous"
},
"template": null
},
{
"name": "Page visits in time",
"width": 50,
"height": 215,
"ordering": 1,
"type": "page.hits.in.time",
"params": {
"flag": ""
},
"template": null
},
{
"name": "Downloads in time",
"width": 50,
"height": 215,
"ordering": 2,
"type": "asset.downloads.in.time",
"params": [],
"template": null
},
{
"name": "Unique vs returning visitors",
"width": 50,
"height": 330,
"ordering": 4,
"type": "unique.vs.returning.leads",
"params": [],
"template": null
},
{
"name": "Upcoming Emails",
"width": 50,
"height": 330,
"ordering": 4,
"type": "upcoming.emails",
"params": [],
"template": null
},
{
"name": "Dwell times",
"width": 50,
"height": 330,
"ordering": 5,
"type": "dwell.times",
"params": [],
"template": null
},
{
"name": "Popular landing pages",
"width": 25,
"height": 330,
"ordering": 6,
"type": "popular.pages",
"params": [],
"template": null
},
{
"name": "Created Landing pages",
"width": 25,
"height": 330,
"ordering": 7,
"type": "created.pages",
"params": [],
"template": null
},
{
"name": "Device granularity",
"width": 25,
"height": 330,
"ordering": 8,
"type": "device.granularity",
"params": [],
"template": null
},
{
"name": "Popular assets",
"width": 25,
"height": 330,
"ordering": 9,
"type": "popular.assets",
"params": [],
"template": null
},
{
"name": "Form Submissions",
"width": 50,
"height": 330,
"ordering": 11,
"type": "submissions.in.time",
"params": [],
"template": null
}
]
}

View File

@@ -0,0 +1,103 @@
{
"name": "Example - Stats Overview",
"description": "Start with a dashboard of 10 widgets that provide statistic about lead generation, engagement, and email interactions.",
"widgets": [
{
"name": "Contacts created",
"width": 50,
"height": 330,
"ordering": 0,
"type": "created.leads.in.time",
"params": {
"lists": "identifiedVsAnonymous",
"flag": null
},
"template": null
},
{
"name": "Visits",
"width": 50,
"height": 330,
"ordering": 1,
"type": "page.hits.in.time",
"params": {
"flag": null
},
"template": null
},
{
"name": "Points",
"width": 50,
"height": 330,
"ordering": 3,
"type": "points.in.time",
"params": [],
"template": null
},
{
"name": "Downloads in time",
"width": 50,
"height": 330,
"ordering": 4,
"type": "asset.downloads.in.time",
"params": [],
"template": null
},
{
"name": "Emails sent \/ opened",
"width": 50,
"height": 330,
"ordering": 5,
"type": "emails.in.time",
"params": {
"flag": null
},
"template": null
},
{
"name": "Submissions in time",
"width": 50,
"height": 330,
"ordering": 6,
"type": "submissions.in.time",
"params": [],
"template": null
},
{
"name": "Identified vs anonymous leads",
"width": 25,
"height": 330,
"ordering": 7,
"type": "anonymous.vs.identified.leads",
"params": [],
"template": null
},
{
"name": "Ignored\/opened emails",
"width": 25,
"height": 330,
"ordering": 8,
"type": "ignored.vs.read.emails",
"params": [],
"template": null
},
{
"name": "Unique\/returning visitors",
"width": 25,
"height": 330,
"ordering": 9,
"type": "unique.vs.returning.leads",
"params": [],
"template": null
},
{
"name": "Dwell times",
"width": 25,
"height": 330,
"ordering": 11,
"type": "dwell.times",
"params": [],
"template": null
}
]
}

View File

@@ -0,0 +1,16 @@
<IfModule mod_php4.c>
php_flag engine Off
</IfModule>
<IfModule mod_php5.c>
php_flag engine Off
</IfModule>
<IfModule mod_php6.c>
php_flag engine Off
</IfModule>
<IfModule mod_cgi.c>
Options -ExecCGI
</IfModule>
RemoveHandler .cgi .pl .py .pyc .pyo .phtml .php .php3 .php4 .php5 .php6 .pcgi .pcgi3 .pcgi4 .pcgi5 .pchi6 .inc
RemoveType .cgi .pl .py .pyc .pyo .phtml .php .php3 .php4 .php5 .php6 .pcgi .pcgi3 .pcgi4 .pcgi5 .pchi6 .inc
SetHandler None
SetHandler default-handler

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 820 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 977 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 206 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 592 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 862 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 617 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 169 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 639 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 983 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 172 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 755 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 467 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 340 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 434 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 444 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 560 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 595 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 178 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 184 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 686 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 734 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 178 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 172 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 430 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 367 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 486 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 696 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 360 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 377 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 181 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 309 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 745 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1004 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 174 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 659 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 184 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 172 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 605 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 441 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 369 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 369 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 180 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 452 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 588 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 726 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 634 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 719 B

Some files were not shown because too many files have changed in this diff Show More