From 3a2b8f4b44cf9594537cc608763dda9ec20b7e3a Mon Sep 17 00:00:00 2001 From: rendies Date: Mon, 12 Dec 2022 19:04:16 +0700 Subject: [PATCH] feat: inital comit --- .idea/.gitignore | 3 + .idea/.name | 1 + .idea/compiler.xml | 6 + .idea/deploymentTargetDropDown.xml | 16 ++ .idea/gradle.xml | 19 ++ .idea/misc.xml | 16 ++ .idea/vcs.xml | 6 + app/.gitignore | 1 + app/build.gradle | 48 +++++ app/proguard-rules.pro | 23 +++ .../ExampleInstrumentedTest.kt | 24 +++ app/src/main/AndroidManifest.xml | 33 +++ .../pocdrivingtracking/MainActivity.kt | 190 ++++++++++++++++++ .../drawable-v24/ic_launcher_foreground.xml | 30 +++ .../res/drawable/ic_launcher_background.xml | 170 ++++++++++++++++ app/src/main/res/layout/activity_main.xml | 35 ++++ .../res/mipmap-anydpi-v26/ic_launcher.xml | 5 + .../mipmap-anydpi-v26/ic_launcher_round.xml | 5 + app/src/main/res/mipmap-hdpi/ic_launcher.webp | Bin 0 -> 1404 bytes .../res/mipmap-hdpi/ic_launcher_round.webp | Bin 0 -> 2898 bytes app/src/main/res/mipmap-mdpi/ic_launcher.webp | Bin 0 -> 982 bytes .../res/mipmap-mdpi/ic_launcher_round.webp | Bin 0 -> 1772 bytes .../main/res/mipmap-xhdpi/ic_launcher.webp | Bin 0 -> 1900 bytes .../res/mipmap-xhdpi/ic_launcher_round.webp | Bin 0 -> 3918 bytes .../main/res/mipmap-xxhdpi/ic_launcher.webp | Bin 0 -> 2884 bytes .../res/mipmap-xxhdpi/ic_launcher_round.webp | Bin 0 -> 5914 bytes .../main/res/mipmap-xxxhdpi/ic_launcher.webp | Bin 0 -> 3844 bytes .../res/mipmap-xxxhdpi/ic_launcher_round.webp | Bin 0 -> 7778 bytes app/src/main/res/values-night/themes.xml | 16 ++ app/src/main/res/values/colors.xml | 10 + app/src/main/res/values/strings.xml | 3 + app/src/main/res/values/themes.xml | 16 ++ app/src/main/res/xml/backup_rules.xml | 13 ++ .../main/res/xml/data_extraction_rules.xml | 19 ++ .../pocdrivingtracking/ExampleUnitTest.kt | 17 ++ build.gradle | 10 + gradle.properties | 23 +++ gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 59203 bytes gradle/wrapper/gradle-wrapper.properties | 6 + gradlew | 185 +++++++++++++++++ gradlew.bat | 89 ++++++++ settings.gradle | 22 ++ 42 files changed, 1060 insertions(+) create mode 100644 .idea/.gitignore create mode 100644 .idea/.name create mode 100644 .idea/compiler.xml create mode 100644 .idea/deploymentTargetDropDown.xml create mode 100644 .idea/gradle.xml create mode 100644 .idea/misc.xml create mode 100644 .idea/vcs.xml create mode 100644 app/.gitignore create mode 100644 app/build.gradle create mode 100644 app/proguard-rules.pro create mode 100644 app/src/androidTest/java/com/empatnusabangsa/pocdrivingtracking/ExampleInstrumentedTest.kt create mode 100644 app/src/main/AndroidManifest.xml create mode 100644 app/src/main/java/com/empatnusabangsa/pocdrivingtracking/MainActivity.kt create mode 100644 app/src/main/res/drawable-v24/ic_launcher_foreground.xml create mode 100644 app/src/main/res/drawable/ic_launcher_background.xml create mode 100644 app/src/main/res/layout/activity_main.xml create mode 100644 app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml create mode 100644 app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml create mode 100644 app/src/main/res/mipmap-hdpi/ic_launcher.webp create mode 100644 app/src/main/res/mipmap-hdpi/ic_launcher_round.webp create mode 100644 app/src/main/res/mipmap-mdpi/ic_launcher.webp create mode 100644 app/src/main/res/mipmap-mdpi/ic_launcher_round.webp create mode 100644 app/src/main/res/mipmap-xhdpi/ic_launcher.webp create mode 100644 app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp create mode 100644 app/src/main/res/mipmap-xxhdpi/ic_launcher.webp create mode 100644 app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp create mode 100644 app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp create mode 100644 app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp create mode 100644 app/src/main/res/values-night/themes.xml create mode 100644 app/src/main/res/values/colors.xml create mode 100644 app/src/main/res/values/strings.xml create mode 100644 app/src/main/res/values/themes.xml create mode 100644 app/src/main/res/xml/backup_rules.xml create mode 100644 app/src/main/res/xml/data_extraction_rules.xml create mode 100644 app/src/test/java/com/empatnusabangsa/pocdrivingtracking/ExampleUnitTest.kt create mode 100644 build.gradle create mode 100644 gradle.properties create mode 100644 gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/wrapper/gradle-wrapper.properties create mode 100644 gradlew create mode 100644 gradlew.bat create mode 100644 settings.gradle diff --git a/.idea/.gitignore b/.idea/.gitignore new file mode 100644 index 0000000..26d3352 --- /dev/null +++ b/.idea/.gitignore @@ -0,0 +1,3 @@ +# Default ignored files +/shelf/ +/workspace.xml diff --git a/.idea/.name b/.idea/.name new file mode 100644 index 0000000..eea1e2e --- /dev/null +++ b/.idea/.name @@ -0,0 +1 @@ +POC Driving Tracking \ No newline at end of file diff --git a/.idea/compiler.xml b/.idea/compiler.xml new file mode 100644 index 0000000..fb7f4a8 --- /dev/null +++ b/.idea/compiler.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/deploymentTargetDropDown.xml b/.idea/deploymentTargetDropDown.xml new file mode 100644 index 0000000..ec3f8e7 --- /dev/null +++ b/.idea/deploymentTargetDropDown.xml @@ -0,0 +1,16 @@ + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/gradle.xml b/.idea/gradle.xml new file mode 100644 index 0000000..a2d7c21 --- /dev/null +++ b/.idea/gradle.xml @@ -0,0 +1,19 @@ + + + + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..c9bde4f --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,16 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/vcs.xml b/.idea/vcs.xml new file mode 100644 index 0000000..94a25f7 --- /dev/null +++ b/.idea/vcs.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/app/.gitignore b/app/.gitignore new file mode 100644 index 0000000..42afabf --- /dev/null +++ b/app/.gitignore @@ -0,0 +1 @@ +/build \ No newline at end of file diff --git a/app/build.gradle b/app/build.gradle new file mode 100644 index 0000000..ca67516 --- /dev/null +++ b/app/build.gradle @@ -0,0 +1,48 @@ +plugins { + id 'com.android.application' + id 'org.jetbrains.kotlin.android' +} + +android { + compileSdk 32 + + defaultConfig { + applicationId "com.empatnusabangsa.pocdrivingtracking" + minSdk 28 + targetSdk 32 + versionCode 1 + versionName "1.0" + + testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" + } + + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' + } + } + compileOptions { + sourceCompatibility JavaVersion.VERSION_1_8 + targetCompatibility JavaVersion.VERSION_1_8 + } + kotlinOptions { + jvmTarget = '1.8' + } + + +} + +dependencies { + + implementation 'androidx.core:core-ktx:1.7.0' + implementation 'androidx.appcompat:appcompat:1.5.1' + implementation 'com.google.android.material:material:1.7.0' + implementation 'androidx.constraintlayout:constraintlayout:2.1.4' + testImplementation 'junit:junit:4.13.2' + androidTestImplementation 'androidx.test.ext:junit:1.1.4' + androidTestImplementation 'androidx.test.espresso:espresso-core:3.5.0' + + implementation "com.telematicssdk:tracking:2.2.255" + implementation "com.telematicssdk:auth:1.0.0" +} \ No newline at end of file diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro new file mode 100644 index 0000000..597946a --- /dev/null +++ b/app/proguard-rules.pro @@ -0,0 +1,23 @@ +# Add project specific ProGuard rules here. +# You can control the set of applied configuration files using the +# proguardFiles setting in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} + +# Uncomment this to preserve the line number information for +# debugging stack traces. +#-keepattributes SourceFile,LineNumberTable + +# If you keep the line number information, uncomment this to +# hide the original source file name. +#-renamesourcefileattribute SourceFile +-keep public class com.raxeltelematics.** {*;} +-keep public class com.telematicssdk.auth.** {*;} \ No newline at end of file diff --git a/app/src/androidTest/java/com/empatnusabangsa/pocdrivingtracking/ExampleInstrumentedTest.kt b/app/src/androidTest/java/com/empatnusabangsa/pocdrivingtracking/ExampleInstrumentedTest.kt new file mode 100644 index 0000000..6e739eb --- /dev/null +++ b/app/src/androidTest/java/com/empatnusabangsa/pocdrivingtracking/ExampleInstrumentedTest.kt @@ -0,0 +1,24 @@ +package com.empatnusabangsa.pocdrivingtracking + +import androidx.test.platform.app.InstrumentationRegistry +import androidx.test.ext.junit.runners.AndroidJUnit4 + +import org.junit.Test +import org.junit.runner.RunWith + +import org.junit.Assert.* + +/** + * Instrumented test, which will execute on an Android device. + * + * See [testing documentation](http://d.android.com/tools/testing). + */ +@RunWith(AndroidJUnit4::class) +class ExampleInstrumentedTest { + @Test + fun useAppContext() { + // Context of the app under test. + val appContext = InstrumentationRegistry.getInstrumentation().targetContext + assertEquals("com.empatnusabangsa.pocdrivingtracking", appContext.packageName) + } +} \ No newline at end of file diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..493e91d --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,33 @@ + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/java/com/empatnusabangsa/pocdrivingtracking/MainActivity.kt b/app/src/main/java/com/empatnusabangsa/pocdrivingtracking/MainActivity.kt new file mode 100644 index 0000000..8c95cbf --- /dev/null +++ b/app/src/main/java/com/empatnusabangsa/pocdrivingtracking/MainActivity.kt @@ -0,0 +1,190 @@ +package com.empatnusabangsa.pocdrivingtracking + +import android.Manifest +import android.content.pm.PackageManager +import android.os.Bundle +import android.util.Log +import android.widget.Button +import android.widget.TextView +import androidx.activity.result.contract.ActivityResultContracts +import androidx.appcompat.app.AppCompatActivity +import androidx.core.app.ActivityCompat +import com.raxeltelematics.v2.sdk.TrackingApi +import com.raxeltelematics.v2.sdk.server.model.Locale +import com.raxeltelematics.v2.sdk.utils.permissions.PermissionsWizardActivity +import com.telematicssdk.auth.TelematicsAuth +import java.time.LocalDateTime +import java.time.ZoneOffset +import java.time.format.DateTimeFormatter +import java.time.temporal.ChronoUnit +import java.util.* + +class MainActivity() : AppCompatActivity() { + private var tracking = TrackingApi.getInstance() + private val INSTANCE_ID = "ef7f9424-f36d-4ee1-90ef-603dfd573bfe" + private val INSTANCE_KEY = "371c9740-1932-4a2e-b256-b0269dba5cdb" + private var DEVICE_TOKEN = "" + private var USER_DEVICE_TOKEN = "9593c574-6487-4e08-80b8-bee912c2fcc0" + + private fun initTracking() { +// tracking = TrackingApi.getInstance(); + tracking.initialize(this); + Log.d("PERMISSION CHECKING", "INIT PERMISSION CHECKING") + val activityResultLauncher = registerForActivityResult(ActivityResultContracts.StartActivityForResult()) {result -> + Log.d("PERMISSION CODE", result.resultCode.toString()) + if (result.resultCode == PermissionsWizardActivity.WIZARD_RESULT_ALL_GRANTED) { + enableTracking() + } + } + + if (!tracking.isAllRequiredPermissionsAndSensorsGranted()){ + val intent = PermissionsWizardActivity.getStartWizardIntent( + this, + enableAggressivePermissionsWizard = true, + enableAggressivePermissionsWizardPage = true + ) + activityResultLauncher.launch(intent) + } else { + var sharedPreferences = this.getPreferences( MODE_PRIVATE) + this.DEVICE_TOKEN = sharedPreferences.getString("DEVICE_TOKEN", "").toString() + tracking.setDeviceID(this.USER_DEVICE_TOKEN) + tracking.startTracking() + Log.d("DEVICE TOKEN", this.DEVICE_TOKEN) + Log.d("USER DEVICE TOKEN", this.USER_DEVICE_TOKEN) + + } + } + + private fun enableTracking() { + if(ActivityCompat.checkSelfPermission( + this, + Manifest.permission.ACCESS_FINE_LOCATION + ) != PackageManager.PERMISSION_GRANTED + ){ + Log.d("PERMISSION", "PERMISSION NOT GRANTED") + + return + } + + + Log.d("INITIATE DEVICE TOKEN", "INITIATE DEVICE TOKEN") + var sharedPreferences = this.getPreferences( MODE_PRIVATE) + this.DEVICE_TOKEN = sharedPreferences.getString("DEVICE_TOKEN", "").toString() + + if(this.DEVICE_TOKEN.isNullOrEmpty()){ + + val uuid = UUID.randomUUID().toString() + + with (sharedPreferences.edit()){ + putString("DEVICE_TOKEN", uuid) +// putString("ACCESS_TOKEN", it.accessToken) +// putString("REFRESH_TOKEN", it.refreshToken) + Log.d("CREATE DEVICE TOKEN", uuid) +// Log.d("CREATE ACCESS TOKEN", it.accessToken) +// Log.d("CREATE REFRESH TOKEN", it.refreshToken) + + apply() + } + this.DEVICE_TOKEN = sharedPreferences.getString("DEVICE_TOKEN", "").toString() + tracking.setDeviceID(this.USER_DEVICE_TOKEN) + tracking.setEnableSdk(true) + tracking.startTracking() + +// TelematicsAuth.createDeviceToken( +// instanceId = this.INSTANCE_ID, +// instanceKey = this.INSTANCE_KEY) +// .onSuccess { +// with (sharedPreferences.edit()){ +// putString("DEVICE_TOKEN", it.deviceToken) +// putString("ACCESS_TOKEN", it.accessToken) +// putString("REFRESH_TOKEN", it.refreshToken) +// Log.d("CREATE DEVICE TOKEN", it.deviceToken) +// Log.d("CREATE ACCESS TOKEN", it.accessToken) +// Log.d("CREATE REFRESH TOKEN", it.refreshToken) +// +// apply() +// } +// this.DEVICE_TOKEN = sharedPreferences.getString("DEVICE_TOKEN", "").toString() +// tracking.setDeviceID(this.USER_DEVICE_TOKEN) +// tracking.setEnableSdk(true) +// tracking.startTracking() +// } +// .onError { e -> +// e.printStackTrace() +// } + } else { + tracking.setDeviceID(this.USER_DEVICE_TOKEN) + tracking.setEnableSdk(true) + tracking.startTracking() + } + + Log.d("DEVICE TOKEN", this.DEVICE_TOKEN) + Log.d("USER DEVICE TOKEN", this.USER_DEVICE_TOKEN) + + + } + + private fun createDeviceToken() { + Log.d("INITIATE DEVICE TOKEN", "INITIATE DEVICE TOKEN") + + TelematicsAuth.createDeviceToken( + instanceId = this.INSTANCE_ID, + instanceKey = this.INSTANCE_KEY) + .onSuccess { + DEVICE_TOKEN = it.deviceToken + Log.d("CREATE DEVICE TOKEN", it.deviceToken) + Log.d("CREATE ACCESS TOKEN", it.accessToken) + Log.d("CREATE REFRESH TOKEN", it.refreshToken) + } + .onError { e -> + e.printStackTrace() + } + } + + override fun onCreate(savedInstanceState: Bundle?) { + super.onCreate(savedInstanceState) + setContentView(R.layout.activity_main) + + initTracking() + + val buttonShowTracking = findViewById(R.id.button_show_tracking) as Button + val textTracking = findViewById(R.id.textTracking) as TextView + + buttonShowTracking.setOnClickListener{ + Log.d("DEVICE TOKEN", this.DEVICE_TOKEN) + Log.d("USER DEVICE TOKEN", this.USER_DEVICE_TOKEN ) + Log.d("IS TRACKING ENABLE", tracking.isTracking().toString()) + val current = LocalDateTime.now().atOffset(ZoneOffset.UTC) + val formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss'+00:00'") + val yesterday = current.minus(1, ChronoUnit.DAYS) + + Log.d("currenttime","Current Date and Time is: " + current.format(formatter)) + val result = tracking.getTracks( + Locale.EN, + null, + null, + 0, + 100) +// val listTripData = +// tripsMapper.transformTripsList(arrayOfTracks.asList()).filter { !it.isDeleted } +// tripsMapper.sort(listTripData, tripData) +// if (listTripData.isNotEmpty()) { +// tripData = listTripData[0] +// } + var logText = "DEVICE ID: " + this.DEVICE_TOKEN + "\n" + logText += "USER ID: " + this.USER_DEVICE_TOKEN + "\n" + logText += "TOTAL DATA: " + result.count() + "\n" + + for (dt in result.asList()){ + logText += "Tracking ID: " + dt.trackId.toString() + "\n" + logText += "tracking: \n" + dt.toString() + "\n" + logText += "=========================\n\n" + Log.d("tracking ID", dt.trackId.toString()) + Log.d("tracking", dt.toString()) + } + + textTracking.text = logText + + } + } +} \ No newline at end of file diff --git a/app/src/main/res/drawable-v24/ic_launcher_foreground.xml b/app/src/main/res/drawable-v24/ic_launcher_foreground.xml new file mode 100644 index 0000000..2b068d1 --- /dev/null +++ b/app/src/main/res/drawable-v24/ic_launcher_foreground.xml @@ -0,0 +1,30 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/drawable/ic_launcher_background.xml b/app/src/main/res/drawable/ic_launcher_background.xml new file mode 100644 index 0000000..07d5da9 --- /dev/null +++ b/app/src/main/res/drawable/ic_launcher_background.xml @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/res/layout/activity_main.xml b/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000..6991ec9 --- /dev/null +++ b/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,35 @@ + + + +