All Projects → scale8 → tag-manager

scale8 / tag-manager

Licence: AGPL-3.0 license
Website analytics, JavaScript error tracking + analytics, tag manager, data ingest endpoint creation (tracking pixels). GDPR + CCPA compliant.

Programming Languages

typescript
32286 projects
java
68154 projects - #9 most used programming language
Twig
543 projects
javascript
184084 projects - #8 most used programming language
Batchfile
5799 projects
Dockerfile
14818 projects

Projects that are alternatives of or similar to tag-manager

Analytics
Simple, open-source, lightweight (< 1 KB) and privacy-friendly web analytics alternative to Google Analytics.
Stars: ✭ 9,469 (+3293.91%)
Mutual labels:  charts, marketing, clickhouse, google-analytics
affiliate
Add affiliation tags to links automatically in the browser
Stars: ✭ 77 (-72.4%)
Mutual labels:  marketing, advertising
Goaccess
GoAccess is a real-time web log analyzer and interactive viewer that runs in a terminal in *nix systems or through your browser.
Stars: ✭ 14,096 (+4952.33%)
Mutual labels:  google-analytics, gdpr
Umami
Umami is a simple, fast, website analytics alternative to Google Analytics.
Stars: ✭ 9,228 (+3207.53%)
Mutual labels:  charts, google-analytics
unified-analytics
ready-to-deploy custom web analytics collection & reporting for government
Stars: ✭ 20 (-92.83%)
Mutual labels:  google-analytics, google-tag-manager
stat-counters
The library, which provides statistics counters, e.g. Google analytics, Yandex metrica, etc
Stars: ✭ 16 (-94.27%)
Mutual labels:  google-analytics, google-tag-manager
Signal
Simple and beautiful open source Analytics 📊
Stars: ✭ 295 (+5.73%)
Mutual labels:  marketing, google-analytics
MetaHeac
This is an official implementation for "Learning to Expand Audience via Meta Hybrid Experts and Critics for Recommendation and Advertising"(KDD2021).
Stars: ✭ 36 (-87.1%)
Mutual labels:  marketing, advertising
target-and-market
A data-driven tool to identify the best candidates for a marketing campaign and optimize it.
Stars: ✭ 19 (-93.19%)
Mutual labels:  bigquery, marketing
growthbook
Open Source Feature Flagging and A/B Testing Platform
Stars: ✭ 2,342 (+739.43%)
Mutual labels:  bigquery, clickhouse
ob google-bigquery
This service is meant to simplify running Google Cloud operations, especially BigQuery tasks. This means you do not have to worry about installation, configuration or ongoing maintenance related to an SDK environment. This can be helpful to those who would prefer to not to be responsible for those activities.
Stars: ✭ 43 (-84.59%)
Mutual labels:  bigquery, google-analytics
privera
Use the tools you know. Respect users' privacy. Forget cookie consents. Comply with GDPR, ePrivacy, COPPA, CalOPPA, PECR, PIPEDA, CASL; you name it.
Stars: ✭ 23 (-91.76%)
Mutual labels:  google-analytics, gdpr
iabtcf-es
Official compliant tool suite for implementing the Transparency and Consent Framework (TCF) v2.0. The essential toolkit for CMPs.
Stars: ✭ 102 (-63.44%)
Mutual labels:  cmp, gdpr
Cookies Eu Banner
1kb vanilla JS script which manages cookies consent banner display like asked by GDPR
Stars: ✭ 326 (+16.85%)
Mutual labels:  google-analytics, gdpr
nextjs-google-analytics
Google Analytics for Next.js
Stars: ✭ 242 (-13.26%)
Mutual labels:  google-analytics, google-tag-manager
Sqlpad
Web-based SQL editor run in your own private cloud. Supports MySQL, Postgres, SQL Server, Vertica, Crate, ClickHouse, Trino, Presto, SAP HANA, Cassandra, Snowflake, BigQuery, SQLite, and more with ODBC
Stars: ✭ 4,113 (+1374.19%)
Mutual labels:  bigquery, clickhouse
shopify-gtm-ga
Enhances Google Analytics and integrates Google Tag Manager for Shopify.
Stars: ✭ 44 (-84.23%)
Mutual labels:  google-analytics, google-tag-manager
mmetrics
Easy computation of Marketing Metrics in R
Stars: ✭ 26 (-90.68%)
Mutual labels:  marketing
hacktoberfest-data
Generating stats from the raw Hacktoberfest application data.
Stars: ✭ 21 (-92.47%)
Mutual labels:  charts
aioch
aioch - is a library for accessing a ClickHouse database over native interface from the asyncio
Stars: ✭ 145 (-48.03%)
Mutual labels:  clickhouse

Scale8 - Tag Manager & Data Manager

Scale8 - An open-source and privacy friendly alternative to GA & GTM | Product Hunt


👀 *MIT License is applied to Platforms to enable network distribution. The rest of the project remains under AGPL v3.

A simple, yet powerful Google Tag Manager alternative that is fully open-sourced and privacy-friendly. Our in-built Google Analytics alternative doesn't use any cookies and is fully GDPR, CCPA and PECR compliant. We've made it quick and easy to try a demo or simply host it yourself in production. We'll also be offering a cloud hosted version in the near future.

The Data Manager provides pluggable backends to send data anywhere, and we've got a pipeline to increase both connectors and features. In just a few clicks, design a schema, configure a back-end and create an endpoint to send data to. The Tag Manager uses this same underlying tech to provide analytics.

Our mission has been to create an intuitive Tag Management tool that can be fully extended via custom platforms (built by our community!). We're a small team that is passionate about building great open-source software and hopefully reducing the market share of much larger companies. We are not a fan of increasing corporate or government surveillance, and we fundamentally believe that your website's users deserve better - this however needs to be balanced with the business requirement to monetise a property and personal data being shared.

Running the project

Here is a one-line example of how to get started if you already have Docker Compose installed.

~> curl -L https://github.com/scale8/scale8/raw/master/docker-compose.yml | docker-compose -f - up

Once the command above has started the services, point your browser at http://127.0.0.1:8080. You will be prompted to enter some basic details to configure the project.

Or if you have checked out the project already and installed the dependencies via ~> yarn install:all and wish to run it locally: -

~> yarn run:all

Platform structure

We've architected the entire platform to support docker and limited where possible complex build processes and mounting of extra volumes. We're scripting hard to provide complete one-click production ready setups for both AWS, Google Cloud and custom kubernetes setups.

Component Description
API Contains all the business logic and provides GraphQL / RESTFul endpoints that power the UI
Common A small common library that is shared between project components
Edge Designed to scale horizontally, the edge server is responsible for delivering platforms at the edge and also tracking data in
Platforms Custom platforms created by the community and Scale8 that extend the functionality of the Tag Manager
Router A simple router, created using Nginx and designed for spinning up the self-hosted version quickly
UI Provides a static build of the UI using Next.js & React

Development - Install dependencies and build

  • Install all project dependencies: ~> yarn install:all
  • Build all projects: ~> yarn build:all

Analytics-only mode

As not everyone has the requirement to use a full Tag Manager, we've also provided an option to generate an extremely light version that only requires a few lines of JavaScript.

We have also provided full support for tracking Single Page Applications (SPAs) and hash-routing. These can be enabled when you install your application.

Features overview

Tag Manager

  • Tags: Create tags that automatically load, or include them on the fly in your application.
  • Rule Groups: Tags can be associated with one or more Rule Groups that can be run in parallel.
  • Rules: Rule groups can contain multiple rules with the first rule winning. Rules can also be repeated once they've won.
  • Events: Attach events to rules as triggers. Once attached they will listen for your chosen event to occur before allowing a rule to proceed.
  • Conditions & Exceptions: Attach conditions and exceptions to rules. These will test your data containers / data layers.
  • Actions: Once events and/or conditions are satisfied, then trigger one or more actions. App-state enables actions to trigger other actions.
  • Action Groups: Action groups contain actions and provide a useful container to separate logic.
  • Action Group Distributions: Run experiments (A/B tests) or monitor just a percentage of traffic. Easily distribute your actions across your users.
  • Installed Platforms: Install 3rd party platforms submitted by our community. These platforms extend Events, Data Containers and Actions.
  • Installed Platform Revisions: A revision is locked to a platform revision. Upgrade and deploy with confidence as connect platforms change.
  • Environments: Create as many environments as your team requires, matching your existing workflows.
  • Revision Control: All changes happen within a new revision. Preview and test without complex release cycles. Deploy with confidence.
  • Debugging: Debug your application with ease. Remote debugging coming soon!
  • Analytics: A simple and intuitive set of analytics tools. Event tracking with Event Group support.
  • Analytics-only Mode: Run an incredibly lightweight snippet of JavaScript code to gain full analytics data.

Data Manager

  • Ingest Endpoints: Generate new endpoints to send data to in just a few clicks.
  • Data Structure: Compose a data structure that is compatible with any backend we offer. Design once, use everywhere.
  • Revisions: Everything sits under revision control. Release with confidence.
  • Usage Monitoring: Track endpoint requests and data usage.
  • Environments: Test your latest data structure without compromising your production setup. Roll-back in seconds.

All products

  • Team Support: Invite team members and manage access levels.
  • Full API Support: Automate everything - The UI is static and calls the GraphQL API for everything.

Core concepts

We've done our best to simplify the process of organising and managing tags across one or more web properties. The Tag Manager is based on an event-driven, rule-based engine whereby a rule is triggered when Events and Conditions and Exceptions are all met, resulting in one or more Actions being taken.

Events

A triggered event within the browser can be easily managed by our simple interface. A clicked link, a page coming into focus, or a submitted form are all examples of events you may wish to listen to.

Conditions & Exceptions

A condition is a test made on a data container and aims to assert that some key belonging to a data container object is aligned with the expected value. An exception aims to make the same test, but instead exclude the rule should the test pass.

Actions

Upon meeting the rule's required events and condition, an action will be fired. Learn more about actions here.

Tech stack

TLDR;

  • UI: Next.js, TypeScript, React, Apollo, GraphQL, Material UI.
  • Edge: Micronaut, Java, Maven.
  • Router: Nginx - Used for self-hosted version only and not required for all setups.
  • API: InversifyJS, Node, TypeScript, Express, MongoDB, Apollo, GraphQL, Jest.
  • Platforms: TypeScript, Webpack, Jest.

A longer explanation

We originally started off with a TypeScript front-end and Scala driven back-end. To provide the code transparency we wanted, coupled with a decision to open-source the project required us to move to almost purely TypeScript with just the edge server in Java. We fundamentally believe the future of this project sits with the open-source community now and there are more TypeScript and Java engineers than Scala engineers.

Just before releasing we've moved from CRA to Next.js too. We've also introduced inversion of control (IOC) in our TypeScript back-end. Our goal is for this project to be as extensible as possible. A plug and play model provides us with the opportunity to provide multiple services and prevent lock-ins.

container.bind<BaseStorage>(TYPES.BackendStorage).to(MongoDBStorage).inSingletonScope();
container.bind<BaseDatabase>(TYPES.BackendDatabase).to(MongoDb).inSingletonScope();
container.bind<BaseLogger>(TYPES.BackendLogger).to(ConsoleLogger).inSingletonScope();
container.bind<BaseEmail>(TYPES.BackendEmail).to(Mailer).inSingletonScope();
container.bind<BaseConfig>(TYPES.BackendConfig).to(EnvironmentConfig).inSingletonScope();

We've taken a similar approach with our Java code too.

@Replaces(StorageInterface.class)
@Singleton
@Requires(property = "backend-storage", value = "google")
public class GoogleStorage implements StorageInterface {
    ...
}

At present, we provide only MongoDB and Google's BigQuery for analytics. MongoDB is only suitable for small projects and for the purpose of demo / testing. We have full Clickhouse support in our yet to be released cloud version, and we'll be adding this support in the self-hosted version shortly along with Redshift and Postgres.

We've also removed our hourly aggregation pipelines from the self-hosted version. This added an unnecessary degree of complexity for the vast majority of use cases. There is a plan to potentially re-introduce this later and should anyone require it, please let us know.

Documentation

All of our documentation is designed for the cloud version of the product, however we'll be adding more detailed documentation for the self-hosted version soon. We've hidden away some features such as payment processing and SSL termination for custom domains that are not relevant to the self-hosted version.

The entire UI is powered by GraphQL using Apollo and the API documentation is automatically generated and easily navigated.

Support us!

All we ask is that you star or watch this on GitHub if you like the project. We'd love people to share and blog about this too! All issues will be responded to quickly in GitHub, and we're excited to see where this goes next.

Authors

Author GitHub LinkedIn
Christopher Beck Christopher Beck on GitHub Christopher Beck on LinkedIn
Alessandro Barzanti Alessandro Barzanti on GitHub Alessandro Barzanti on LinkedIn
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].