Skip to content

Commit

Permalink
RDB Loader: bump snowplow-scala-tracker to 0.6.1 (close #148)
Browse files Browse the repository at this point in the history
  • Loading branch information
chuwy committed Aug 13, 2019
1 parent d667f69 commit 06dadb7
Show file tree
Hide file tree
Showing 5 changed files with 34 additions and 30 deletions.
1 change: 1 addition & 0 deletions build.sbt
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ lazy val loader = project.in(file("."))
Dependencies.igluClient,
Dependencies.igluCoreCirce,
Dependencies.scalaTracker,
Dependencies.scalaTrackerEmit,
Dependencies.catsFree,
Dependencies.circeYaml,
Dependencies.circeGeneric,
Expand Down
27 changes: 14 additions & 13 deletions project/Dependencies.scala
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ object Dependencies {
val decline = "0.6.2"
val igluClient = "0.6.0"
val igluCore = "0.5.1"
val scalaTracker = "0.5.0"
val scalaTracker = "0.6.1"
val circeYaml = "0.9.0"
val circe = "0.11.1"
val circeOptics = "0.11.0"
Expand Down Expand Up @@ -53,18 +53,19 @@ object Dependencies {
)

// Scala (Loader)
val decline = "com.monovore" %% "decline" % V.decline
val igluClient = "com.snowplowanalytics" %% "iglu-scala-client" % V.igluClient
val scalaTracker = "com.snowplowanalytics" %% "snowplow-scala-tracker" % V.scalaTracker
val manifest = "com.snowplowanalytics" %% "snowplow-processing-manifest" % V.manifest
val igluCoreCirce = "com.snowplowanalytics" %% "iglu-core-circe" % V.igluCore
val cats = "org.typelevel" %% "cats" % V.cats
val catsFree = "org.typelevel" %% "cats-free" % V.cats
val circeCore = "io.circe" %% "circe-core" % V.circe
val circeGeneric = "io.circe" %% "circe-generic" % V.circe
val circeGenericExtra = "io.circe" %% "circe-generic-extras" % V.circe
val circeYaml = "io.circe" %% "circe-yaml" % V.circeYaml
val fs2 = "co.fs2" %% "fs2-core" % V.fs2
val decline = "com.monovore" %% "decline" % V.decline
val igluClient = "com.snowplowanalytics" %% "iglu-scala-client" % V.igluClient
val scalaTracker = "com.snowplowanalytics" %% "snowplow-scala-tracker-core" % V.scalaTracker
val scalaTrackerEmit = "com.snowplowanalytics" %% "snowplow-scala-tracker-emitter-id" % V.scalaTracker
val manifest = "com.snowplowanalytics" %% "snowplow-processing-manifest" % V.manifest
val igluCoreCirce = "com.snowplowanalytics" %% "iglu-core-circe" % V.igluCore
val cats = "org.typelevel" %% "cats" % V.cats
val catsFree = "org.typelevel" %% "cats-free" % V.cats
val circeCore = "io.circe" %% "circe-core" % V.circe
val circeGeneric = "io.circe" %% "circe-generic" % V.circe
val circeGenericExtra = "io.circe" %% "circe-generic-extras" % V.circe
val circeYaml = "io.circe" %% "circe-yaml" % V.circeYaml
val fs2 = "co.fs2" %% "fs2-core" % V.fs2

// Scala (Shredder)
val analyticsSdk = "com.snowplowanalytics" %% "snowplow-scala-analytics-sdk" % V.analyticsSdk
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ import implementations.ManifestInterpreter.ManifestE
class DryRunInterpreter private[interpreters](
cliConfig: CliConfig,
amazonS3: AmazonS3,
tracker: Option[Tracker],
tracker: Option[Tracker[Id]],
resolver: Client[Id, Json]) extends Interpreter {

private val logQueries = ListBuffer.empty[SqlString]
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ import com.snowplowanalytics.snowplow.rdbloader.loaders.Common.SqlString
class RealWorldInterpreter private[interpreters](
cliConfig: CliConfig,
amazonS3: AmazonS3,
tracker: Option[Tracker],
tracker: Option[Tracker[Id]],
resolver: Client[Id, Json]) extends Interpreter {

private val interpreter = this
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,26 +19,28 @@ import java.nio.charset.StandardCharsets

import scala.util.control.NonFatal

import cats.Id
import cats.data.NonEmptyList

import io.circe.Json

import com.amazonaws.services.s3.AmazonS3
import com.amazonaws.services.s3.model.ObjectMetadata

import org.json4s.JObject

import org.joda.time.DateTime

import com.snowplowanalytics.iglu.core.{SchemaKey, SchemaVer, SelfDescribingData}

import com.snowplowanalytics.snowplow.scalatracker._
import com.snowplowanalytics.snowplow.scalatracker.emitters.TEmitter._
import com.snowplowanalytics.snowplow.scalatracker.emitters.{AsyncBatchEmitter, AsyncEmitter}
import com.snowplowanalytics.snowplow.scalatracker.emitters.id._
import com.snowplowanalytics.snowplow.scalatracker.emitters.id.RequestProcessor._
import com.snowplowanalytics.snowplow.scalatracker.emitters.id.{SyncBatchEmitter, SyncEmitter}

// This project
import config.SnowplowConfig.{GetMethod, Monitoring, PostMethod}

object TrackerInterpreter {

import scala.concurrent.ExecutionContext.Implicits.global

val ApplicationContextSchema = SchemaKey("com.snowplowanalytics.monitoring.batch", "application_context", "jsonschema", SchemaVer.Full(1,0,0))
val LoadSucceededSchema = SchemaKey("com.snowplowanalytics.monitoring.batch", "load_succeeded", "jsonschema", SchemaVer.Full(1,0,0))
val LoadFailedSchema = SchemaKey("com.snowplowanalytics.monitoring.batch", "load_failed", "jsonschema", SchemaVer.Full(1,0,0))
Expand Down Expand Up @@ -74,18 +76,18 @@ object TrackerInterpreter {
* @param monitoring config.yml `monitoring` section
* @return some tracker if enabled, none otherwise
*/
def initializeTracking(monitoring: Monitoring): Option[Tracker] = {
def initializeTracking(monitoring: Monitoring): Option[Tracker[Id]] = {
monitoring.snowplow.flatMap(_.collector) match {
case Some(Collector((host, port))) =>
val emitter = monitoring.snowplow.flatMap(_.method) match {
case Some(GetMethod) =>
AsyncEmitter.createAndStart(host, port = Some(port), callback = Some(callback))
SyncEmitter.createAndStart(host, port = Some(port), callback = Some(callback))
case Some(PostMethod) =>
AsyncBatchEmitter.createAndStart(host, port = Some(port), bufferSize = 2)
SyncBatchEmitter.createAndStart(host, port = Some(port), bufferSize = 2)
case None =>
AsyncEmitter.createAndStart(host, port = Some(port), callback = Some(callback))
SyncEmitter.createAndStart(host, port = Some(port), callback = Some(callback))
}
val tracker = new Tracker(List(emitter), "snowplow-rdb-loader", monitoring.snowplow.flatMap(_.appId).getOrElse("rdb-loader"))
val tracker = new Tracker[Id](NonEmptyList.of(emitter), "snowplow-rdb-loader", monitoring.snowplow.flatMap(_.appId).getOrElse("rdb-loader"))
Some(tracker)
case Some(_) => None
case None => None
Expand All @@ -97,9 +99,9 @@ object TrackerInterpreter {
*
* @param tracker some tracker if enabled
*/
def trackError(tracker: Option[Tracker]): Unit = tracker match {
def trackError(tracker: Option[Tracker[Id]]): Unit = tracker match {
case Some(t) =>
t.trackSelfDescribingEvent(SelfDescribingData(LoadFailedSchema, JObject(Nil)))
t.trackSelfDescribingEvent(SelfDescribingData(LoadFailedSchema, Json.fromFields(List.empty)))
case None => ()
}

Expand All @@ -108,9 +110,9 @@ object TrackerInterpreter {
*
* @param tracker some tracker if enabled
*/
def trackSuccess(tracker: Option[Tracker]): Unit = tracker match {
def trackSuccess(tracker: Option[Tracker[Id]]): Unit = tracker match {
case Some(t) =>
t.trackSelfDescribingEvent(SelfDescribingData(LoadSucceededSchema, JObject(Nil)))
t.trackSelfDescribingEvent(SelfDescribingData(LoadSucceededSchema, Json.fromFields(List.empty)))
case None => ()
}

Expand Down

0 comments on commit 06dadb7

Please sign in to comment.