use base64 encoded private key for apns

This commit is contained in:
2025-02-11 11:46:46 -08:00
parent 9af48be746
commit ebcd35b85d
2 changed files with 7 additions and 15 deletions

View File

@@ -52,9 +52,10 @@ export class NotificationService {
const keyId = process.env.APNS_KEY_ID; const keyId = process.env.APNS_KEY_ID;
const teamId = process.env.APNS_TEAM_ID; const teamId = process.env.APNS_TEAM_ID;
const privateKeyPath = process.env.APNS_KEY_PATH;
if (!privateKeyPath) return; const privateKeyBase64 = process.env.APNS_PRIVATE_KEY;
const privateKey = fs.readFileSync(privateKeyPath); if (!privateKeyBase64) return;
const privateKey = Buffer.from(privateKeyBase64, 'base64').toString('utf-8');
const tokenHeader = { const tokenHeader = {
alg: "ES256", alg: "ES256",

View File

@@ -1,21 +1,14 @@
import { beforeEach, describe, expect, it, jest } from "@jest/globals"; import { beforeEach, describe, expect, it, jest } from "@jest/globals";
import { NotificationService } from "../../src/services/NotificationService"; import { NotificationService } from "../../src/services/NotificationService";
import { UnoptimizedInMemoryRepository } from "../../src/repositories/UnoptimizedInMemoryRepository"; import { UnoptimizedInMemoryRepository } from "../../src/repositories/UnoptimizedInMemoryRepository";
import fs from "fs";
import http2 from "http2"; import http2 from "http2";
import { IEta, IShuttle, IStop } from "../../src/entities/entities"; import { IEta, IShuttle, IStop } from "../../src/entities/entities";
import { addMockShuttleToRepository, addMockStopToRepository } from "../testHelpers/repositorySetupHelpers"; import { addMockShuttleToRepository, addMockStopToRepository } from "../testHelpers/repositorySetupHelpers";
import EventEmitter = require("node:events"); import EventEmitter = require("node:events");
jest.mock("fs");
jest.mock("http2"); jest.mock("http2");
const sampleKey = `-----BEGIN PRIVATE KEY----- const sampleKeyBase64 = "LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JR1RBZ0VBTUJNR0J5cUdTTTQ5QWdFR0NDcUdTTTQ5QXdFSEJIa3dkd0lCQVFRZ3NybVNBWklhZ09mQ1A4c0IKV2kyQ0JYRzFPbzd2MWJpc3BJWkN3SXI0UkRlZ0NnWUlLb1pJemowREFRZWhSQU5DQUFUWkh4VjJ3UUpMTUJxKwp5YSt5ZkdpM2cyWlV2NmhyZmUrajA4eXRla1BIalhTMHF6Sm9WRUx6S0hhNkVMOVlBb1pEWEJ0QjZoK2ZHaFhlClNPY09OYmFmCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0K";
MIGTAgEAMBMGByqGSM49AgEGCCqGSM49AwEHBHkwdwIBAQQgsrmSAZIagOfCP8sB
Wi2CBXG1Oo7v1bispIZCwIr4RDegCgYIKoZIzj0DAQehRANCAATZHxV2wQJLMBq+
ya+yfGi3g2ZUv6hrfe+j08ytekPHjXS0qzJoVELzKHa6EL9YAoZDXBtB6h+fGhXe
SOcONbaf
-----END PRIVATE KEY-----`
/** /**
* Wait for a condition to become true until the timeout * Wait for a condition to become true until the timeout
@@ -75,11 +68,9 @@ describe("NotificationService", () => {
...process.env, ...process.env,
APNS_KEY_ID: "1", APNS_KEY_ID: "1",
APNS_TEAM_ID: "1", APNS_TEAM_ID: "1",
APNS_KEY_PATH: "./dummy-path.p8", APNS_BUNDLE_ID: "dev.bchen.ProjectInter",
APNS_BUNDLE_ID: "dev.bchen.ProjectInter" APNS_PRIVATE_KEY: sampleKeyBase64,
}; };
(fs.readFileSync as jest.Mock).mockReturnValue(sampleKey);
}); });
beforeEach(() => { beforeEach(() => {