https://github.com/init-io/javase
Javase is a simple, fast, and asynchronous Java library designed to streamline Firebase interactions, including Firebase Authentication, Database, and Storage. With easy-to-use APIs and seamless integration, Javase allows developers to quickly add Firebase functionality to their Java-based applications, keeping performance smooth and efficient.
https://github.com/init-io/javase
android android-application android-studio asynchronous-programming backenddevelopment cloudbackend cloudstorage devtools firebase firebase-auth firebase-database firebase-realtime-database firebase-storage firebaseintegration gradle java javalibrary maven mobiledev
Last synced: 15 days ago
JSON representation
Javase is a simple, fast, and asynchronous Java library designed to streamline Firebase interactions, including Firebase Authentication, Database, and Storage. With easy-to-use APIs and seamless integration, Javase allows developers to quickly add Firebase functionality to their Java-based applications, keeping performance smooth and efficient.
- Host: GitHub
- URL: https://github.com/init-io/javase
- Owner: Init-io
- License: mit
- Created: 2025-01-22T09:26:32.000Z (about 1 month ago)
- Default Branch: main
- Last Pushed: 2025-02-04T18:22:34.000Z (17 days ago)
- Last Synced: 2025-02-04T19:25:33.474Z (17 days ago)
- Topics: android, android-application, android-studio, asynchronous-programming, backenddevelopment, cloudbackend, cloudstorage, devtools, firebase, firebase-auth, firebase-database, firebase-realtime-database, firebase-storage, firebaseintegration, gradle, java, javalibrary, maven, mobiledev
- Language: Java
- Homepage:
- Size: 487 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Javase: Firebase? More Like Java-Ease! π
data:image/s3,"s3://crabby-images/e535b/e535b955d76f520039b212d43816f9c46c75fe48" alt="Maven Central"
data:image/s3,"s3://crabby-images/5507e/5507eef4b3e40a04cce63dc50719aeee9922f381" alt="GitHub Release"
[data:image/s3,"s3://crabby-images/259b8/259b8632587f624b0c452bbf19fcfa088a5083c8" alt="License"](LICENSE)
data:image/s3,"s3://crabby-images/cedc1/cedc15621ce754b11c0a30b736c44f9c13ce4b82" alt="downloads"**Version v1.2.3**
*(Because good things come in threes)*---
### π Introduction
Welcome to **Javase** β a Java library so smooth, itβll make working with Firebase feel like a walk in the park. Firebase can be a maze of APIs and JSON responses, but fear not! Javase is here to give you simple, streamlined, and asynchronous solutions for Firebase Database and Firebase Storage.Think of it as your over-caffeinated, always-on-call Firebase assistant who actually *does what itβs told*. π
---
### π Features
#### Database Module:
- **CRUD without the Drama**: Perform `get`, `put`, `update`, and `remove` operations on Firebase Realtime Database. No sweat, no mess, just pure JSON magic.
- **Error Handling That Cares**: Get detailed error messages because "Unknown Error Occurred" isn't good enough.
- **Asynchronous Brilliance**: All tasks run on a separate thread, so your main thread can sip coffee in peace. β#### Storage Module:
- **File Uploading (a.k.a. "Here, Take My Stuff!")**: Upload files to Firebase Storage with minimal effort.
- **Download URLs**: Retrieve public download URLs for your files faster than your WiFi can fail you.
- **Photo Listing**: Get a list of all your photos stored in Firebase. Finally, an easy way to inventory your cat pictures. π±
- **File Deletion**: Ruthlessly delete photos from Firebase Storage (because not every selfie is worth keeping).---
### π οΈ Installation
#### Maven:
```xmlio.github.initio
javase
1.2.3```
#### Gradle:
```groovy
implementation 'io.github.init-io:javase:1.2.3'
```---
### π¦ How to Use
Hereβs a quick peek at how ridiculously easy it is to make Firebase work for you with **Javase**.#### 1. **Authenticaton Module**:
```java
Server server = new Server();
server.initialize(apiKey,authDomain,databaseUrl,storageBucket);
Authentication auth = new Authenticaton(server);//SignUp
auth.signUp(email,password);//SignIn
auth.signIn(email,password);//Get idTokem
auth.getIdToken(); //expires in 1 hour//Refresh toke
auth.refreshIdToken();//Check if user is verified
auth.isVerified(auth.getIdToken());//Verify user
auth.verifyUser(auth.getIdToken());//Reset user password
auth.resetUser(email);//Remove an user
auth.removeUser(auth.getIdToken());```
#### 2. **Database Module**:
```java
Server server = new Server();
server.initialize(apiKey,authDomain,databaseUrl,storageBucket);
Database database = new Database(server);// Fetch data
String response = database.get("path/to/data", "id-token");
System.out.println("Database says: " + response);// Add data
String putResponse = database.put("users/123", "name", "Java Enthusiast", "id-token");
System.out.println("Put Response: " + putResponse);// Update data
String updateResponse = database.update("users/123", "status", "awesome", "id-token");
System.out.println("Update Response: " + updateResponse);// Delete data
String deleteResponse = database.remove("users/123", "id-token");
System.out.println("Delete Response: " + deleteResponse);```
#### 3. **Storage Module**:
```java
Storage storage = new Storage(server, new Authenticate("id-token"));// Upload a file
String uploadResponse = storage.uploadFile("/local/path/to/photo.jpg", "images/photo.jpg");
System.out.println("Upload Response: " + uploadResponse);// Get a file URL
String fileUrl = storage.getFileUrl("images/photo.jpg");
System.out.println("Download URL: " + fileUrl);// List all photos
String photos = storage.listPhotos("images");
System.out.println("Available Photos: " + photos);// Delete a photo
String deletePhotoResponse = storage.deletePhoto("images/photo.jpg");
System.out.println("Delete Response: " + deletePhotoResponse);
```---
### π Error Handling
Whenever things go sideways (and let's face it, they will), **Javase** has your back with a `error()` method that provides detailed error messages.Example:
```java
String result = database.get("non/existent/path", "id-token");
if (result == null) {
System.out.println("Uh oh: " + database.error());
}
```No more vague error messages like "Something went wrong." With Javase, youβll get errors that actually tell you *what* went wrong. Revolutionary, isnβt it? π¨
---
### π€ Why Choose Javase?
1. **Asynchronous Operations**: Multithreading without the headache.
2. **Simple API**: Minimal boilerplate. Maximum productivity.
3. **Readable Errors**: You'll know exactly why Firebase isn't cooperating.
4. **Cool Factor**: Saying "I use Javase" sounds way better than "I wrestle with Firebase APIs."---
### π€ Contributing
Want to make Javase even better? Fork it, fix it, or file an issue. Just make sure your code is cleaner than your desk. π---
### π License
This project is licensed under the [MIT License](LICENSE). In short: use it, modify it, but donβt blame us if you break it.---
### π¬ Closing Words
Firebase is great, but letβs be honest β their APIs can be... *quirky*. Javase turns those quirks into an elegant experience. So, go ahead: download, experiment, and enjoy Firebase like never before.Remember, **lifeβs too short for bad libraries.** π§βπ»