Compare commits

..

3 Commits

7 changed files with 53 additions and 39 deletions
+3 -3
View File
@@ -1,10 +1,10 @@
[package]
name = "tauri-plugin-bluclas"
version = "0.1.0"
authors = [ "Rizky Denianto" ]
authors = [ "You" ]
description = ""
edition = "2024"
rust-version = "1.94.1"
edition = "2021"
rust-version = "1.77.2"
exclude = ["/examples", "/dist-js", "/guest-js", "/node_modules"]
links = "tauri-plugin-bluclas"
+34 -20
View File
@@ -33,7 +33,7 @@ class KirimArgs {
]
)
class BluclasPlugin(private val activity: Activity) : Plugin(activity) {
private val uuidSpp: UUID = UUID.fromString("00001101-0000-1000-8000-00805F9B34FB")
private val SPP_UUID: UUID = UUID.fromString("00001101-0000-1000-8000-00805F9B34FB")
private val adapter: BluetoothAdapter? = this.activity.getSystemService(BluetoothManager::class.java).getAdapter()
private var soket: BluetoothSocket? = null
@@ -59,41 +59,55 @@ class BluclasPlugin(private val activity: Activity) : Plugin(activity) {
invoke.resolve(objekDaftarRes)
}
fun menghubungkanKoneksi(alamat: String) {
val perangkat: BluetoothDevice = adapter!!.getRemoteDevice(alamat)
soket = perangkat.createInsecureRfcommSocketToServiceRecord(uuidSpp)
soket!!.connect()
keluaran = soket!!.outputStream
fun menghubungkanKoneksi(invoke: Invoke, alamat: String) {
try {
val perangkat: BluetoothDevice = adapter!!.getRemoteDevice(alamat)
soket = perangkat.createRfcommSocketToServiceRecord(SPP_UUID)
soket!!.connect()
keluaran = soket!!.outputStream
} catch (e: Exception) {
invoke.reject("Koneksi dengan perangkat gagal: ${e.message}")
}
invoke.resolve()
}
fun memutusKoneksi() {
keluaran?.close()
keluaran = null
soket?.close()
soket = null
fun memutusKoneksi(invoke: Invoke) {
try {
keluaran?.close()
keluaran = null
soket?.close()
soket = null
} catch (e: Exception) {
invoke.reject("Memutus koneksi perangkat gagal")
}
invoke.resolve()
}
@Command
fun kirim(invoke: Invoke) {
val args = invoke.parseArgs(KirimArgs::class.java)
menghubungkanKoneksi(invoke, args.alamat ?: "")
if (keluaran == null) {
invoke.reject("Tidak ada perangkat yang terhubung")
return
}
try {
menghubungkanKoneksi(args.alamat ?: "")
if (keluaran == null) {
throw Exception("Tidak ada perangkat yang terhubung")
}
keluaran!!.write(args.data)
keluaran!!.flush()
} catch (e: Exception) {
memutusKoneksi()
memutusKoneksi(invoke)
invoke.reject("Mengirim data ke perangkat gagal: ${e.message}")
return
}
memutusKoneksi()
memutusKoneksi(invoke)
invoke.resolve()
}
}
+1 -1
View File
@@ -1,7 +1,7 @@
{
"name": "tauri-plugin-bluclas-api",
"version": "0.1.0",
"author": "Rizky Denianto",
"author": "You",
"description": "",
"type": "module",
"types": "./dist-js/index.d.ts",
+4 -4
View File
@@ -1,20 +1,20 @@
use tauri::{AppHandle, Runtime, command};
use tauri::{command, AppHandle, Runtime};
use crate::models::*;
use crate::BluclasExt;
use crate::Result;
use crate::models::*;
#[command]
pub(crate) async fn daftar_perangkat<R: Runtime>(
app: AppHandle<R>,
) -> Result<SBlueclasResponDaftarPerangkat> {
) -> Result<SBlueclasClassicResponDaftarPerangkat> {
return app.bluclas().daftar_perangkat();
}
#[command]
pub(crate) async fn kirim<R: Runtime>(
app: AppHandle<R>,
payload: SBlueclasMuatanKirim,
payload: SBlueclasClassicMuatanKirim,
) -> Result<()> {
return app.bluclas().kirim(payload);
}
+4 -4
View File
@@ -1,5 +1,5 @@
use serde::de::DeserializeOwned;
use tauri::{AppHandle, Runtime, plugin::PluginApi};
use tauri::{plugin::PluginApi, AppHandle, Runtime};
use crate::models::*;
@@ -14,11 +14,11 @@ pub fn init<R: Runtime, C: DeserializeOwned>(
pub struct Bluclas<R: Runtime>(AppHandle<R>);
impl<R: Runtime> Bluclas<R> {
pub fn daftar_perangkat(&self) -> crate::Result<SBlueclasResponDaftarPerangkat> {
return Ok(SBlueclasResponDaftarPerangkat { data: vec![] });
pub fn daftar_perangkat(&self) -> crate::Result<SBlueclasClassicResponDaftarPerangkat> {
return Ok(SBlueclasClassicResponDaftarPerangkat { data: vec![] });
}
pub fn kirim(&self, _: SBlueclasMuatanKirim) -> crate::Result<()> {
pub fn kirim(&self, _: SBlueclasClassicMuatanKirim) -> crate::Result<()> {
return Ok(());
}
}
+3 -3
View File
@@ -1,7 +1,7 @@
use serde::de::DeserializeOwned;
use tauri::{
AppHandle, Runtime,
plugin::{PluginApi, PluginHandle},
AppHandle, Runtime,
};
use crate::models::*;
@@ -25,14 +25,14 @@ pub fn init<R: Runtime, C: DeserializeOwned>(
pub struct Bluclas<R: Runtime>(PluginHandle<R>);
impl<R: Runtime> Bluclas<R> {
pub fn daftar_perangkat(&self) -> crate::Result<SBlueclasResponDaftarPerangkat> {
pub fn daftar_perangkat(&self) -> crate::Result<SBlueclasClassicResponDaftarPerangkat> {
return self
.0
.run_mobile_plugin("daftarPerangkat", ())
.map_err(Into::into);
}
pub fn kirim(&self, payload: SBlueclasMuatanKirim) -> crate::Result<()> {
pub fn kirim(&self, payload: SBlueclasClassicMuatanKirim) -> crate::Result<()> {
return self
.0
.run_mobile_plugin("kirim", payload)
+4 -4
View File
@@ -2,20 +2,20 @@ use serde::{Deserialize, Serialize};
#[derive(Debug, Clone, Default, Deserialize, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct SDaftarPerangkatBlueclasResponDaftarPerangkat {
pub struct SDaftarPerangkatBlueclasClassicResponDaftarPerangkat {
pub nama: String,
pub alamat: String,
}
#[derive(Debug, Clone, Default, Deserialize, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct SBlueclasResponDaftarPerangkat {
pub data: Vec<SDaftarPerangkatBlueclasResponDaftarPerangkat>,
pub struct SBlueclasClassicResponDaftarPerangkat {
pub data: Vec<SDaftarPerangkatBlueclasClassicResponDaftarPerangkat>,
}
#[derive(Debug, Deserialize, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct SBlueclasMuatanKirim {
pub struct SBlueclasClassicMuatanKirim {
pub alamat: String,
pub data: Vec<u8>,
}