Firebase PNV genel önizlemesinde Firebase Authentication, oturum açma için doğrudan bir Firebase PNV jetonunu kabul edemez. Ancak Firebase Authentication'ın özel kimlik doğrulama özelliğini kullanarak kullanıcıların Firebase PNV ile oturum açmasını sağlayabilirsiniz.
Jeton değişimi uç noktası oluşturma
Firebase'de özel kimlik doğrulama çözümü uygulamanın temel adımı, Firebase PNV jetonunu alabilen, doğrulayabilen ve ardından Firebase özel kimlik doğrulama jetonu verebilen bir uç nokta oluşturmaktır. Uygulamanız daha sonra kullanıcı oturumunu açmak için bu özel jetonu kullanabilir.
Bu uç nokta herhangi bir platformda barındırılabilir ancak aşağıdaki örnekte uç nokta, Firebase için Cloud Functions kullanılarak barındırılmaktadır:
Node.js
import { JwtVerifier } from "aws-jwt-verify";
import { getApp } from "firebase-admin/app";
import { getAuth, UserRecord } from "firebase-admin/auth";
import { onRequest } from "firebase-functions/https";
// Because we're deploying to Cloud Functions for Firebase, admin credentials
// are automatically available.
const app = getApp();
const authAdmin = getAuth(app);
// Find your Firebase project number in the Firebase console.
const FIREBASE_PROJECT_NUMBER = "123456789";
// The issuer and audience claims of the FPNV token are specific to your
// project.
const issuer = `https://fpnv.googleapis.com/projects/${FIREBASE_PROJECT_NUMBER}`;
const audience = `https://fpnv.googleapis.com/projects/${FIREBASE_PROJECT_NUMBER}`;
// The JWKS URL contains the current public signing keys for FPNV tokens.
const jwksUri = "https://fpnv.googleapis.com/v1beta/jwks";
// Configure a JWT verifier to check the following:
// - The token is signed by Google
// - The issuer and audience claims match your project
// - The token has not yet expired (default begavior)
const fpnvVerifier = JwtVerifier.create({ issuer, audience, jwksUri });
// This Cloud Function is your token exchange endpoint. You pass the endpoint an
// FPNV token, and the Cloud Function verifies it and exchanges it for a
// Firebase Auth token corresponding to the same user.
export const signInWithFpnv = onRequest(async (req, res) => {
// Get the FPNV token from the request body.
const fpnvToken = req.body?;
if (!fpnvToken) {
res.sendStatus(400);
return;
}
let verifiedPhoneNumber;
try {
// Attempt to verify the token using the verifier configured above.
const verifiedPayload = await fpnvVerifier.verify(fpnvToken);
// If verification succeeds, the subject claim of the token contains the
// verified phone number.
verifiedPhoneNumber = verifiedPayload.sub;
} catch {
// If verification fails, reject the token.
res.sendStatus(403);
return;
}
// Now that you have a verified phone number, look it up in your Firebase
// project's user database.
let user: UserRecord;
try {
// If a user account already exists with the phone number, retrieve it.
user = await authAdmin.getUserByPhoneNumber(verifiedPhoneNumber);
} catch {
// Otherwise, create a new user account using the phone number.
user = await authAdmin.createUser({phoneNumber: verifiedPhoneNumber});
}
// Finally, mint a Firebase custom auth token containing the UID of the user
// you looked up or created. Return this token to the caller.
const authToken = await authAdmin.createCustomToken(user.uid);
res.status(200).send(authToken);
return;
});
Özel kimlik doğrulama jetonuyla oturum açma
Uç nokta dağıtıldıktan sonra aşağıdaki adımları uygulayarak kullanıcıların Firebase'de oturum açmasını sağlayın:
Firebase Phone Number Verification ile çalışmaya başlama sayfasında açıklanan akışı kullanarak bir Firebase PNV jetonu alın.
Bu jetonu Cloud Functions uç noktasına iletin. Uç nokta, uygulamanıza özel bir kimlik doğrulama jetonu döndürür. Bu jetonu
signInWithCustomToken()
'a iletebilirsiniz.Örneğin, Firebase'in
signInWithFpnvToken()
yöntemlerinden birine benzer bir arayüze sahip bir yöntem yazmak için Retrofit'i kullanabilirsiniz:signin
:Kotlin
class FpnvSigninExample { interface FPNVTokenExchangeService { @POST("signInWithFpnv") suspend fun signInWithFpnv(@Body fpnvToken: String): String } val retrofit = Retrofit.Builder() .baseUrl("https://example-project.cloudfunctions.net/") .build() val service: FPNVTokenExchangeService = retrofit.create(FPNVTokenExchangeService::class.java) suspend fun signInWithFpnvToken(fpnvToken: String): Task<AuthResult?> = coroutineScope { val authToken = service.signInWithFpnv(fpnvToken) return@coroutineScope Firebase.auth.signInWithCustomToken(authToken) } }