Skip to content

Commit

Permalink
Refactoring
Browse files Browse the repository at this point in the history
  • Loading branch information
jvik committed Dec 23, 2024
1 parent 8b730ef commit 98aa382
Show file tree
Hide file tree
Showing 5 changed files with 32 additions and 16 deletions.
6 changes: 6 additions & 0 deletions biome.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,5 +15,11 @@
"formatter": {
"enabled": true,
"indentStyle": "space"
},
"files": {
"ignore": [
"node_modules/**",
"dist/**"
]
}
}
8 changes: 4 additions & 4 deletions src/auth.ts
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ async function exchangeCodeForIdAndAuthToken(code: string): Promise<IdTokenRespo
// return response.data;
// }

async function getElawayToken(accessToken: string, idToken: string): Promise<ElawayTokenResponse> {
async function getBearerToken(accessToken: string, idToken: string): Promise<ElawayTokenResponse> {
try {
console.info("Requesting Elaway token with access token and ID token.");
const response = await axios.post(ampecoApiUrl, {
Expand All @@ -128,11 +128,11 @@ async function getElawayToken(accessToken: string, idToken: string): Promise<Ela
throw new Error(`Failed to get Elaway token: ${response.statusText}`);
}

console.info("Successfully obtained Elaway token.");
console.info("Successfully obtained bearer token.");
return response.data;
} catch (error) {
console.error("Error in getElawayToken:", error.message);
console.error("You likely have the wrong ELAWAY_CLIENT_ID or ELAWAY_CLIENT_SECRET");
console.error("You likely have the wrong ELAWAY_CLIENT_ID and/or ELAWAY_CLIENT_SECRET");
throw error;
}
}
Expand Down Expand Up @@ -198,7 +198,7 @@ async function startOauth(): Promise<ElawayTokenResponse> {

accessIdResponse = await exchangeCodeForIdAndAuthToken(code);

tokenResponse = await getElawayToken(accessIdResponse.access_token, accessIdResponse.id_token);
tokenResponse = await getBearerToken(accessIdResponse.access_token, accessIdResponse.id_token);
}
} catch (error) {
console.error(error.message);
Expand Down
11 changes: 11 additions & 0 deletions src/charger/charger.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import config from '../config.js';
import axios from 'axios';

const chargerData = (await axios.get(`${config.ampecoApiUrl}/personal/charge-points`)).data.data[0];

const chargerInfo = {
chargerId: chargerData.id,
evseId: chargerData.evses[0].id
}

export { chargerInfo };
2 changes: 1 addition & 1 deletion src/charger/chargerRouter.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import express from "express";
import axios from "axios";
import config from "../config.js";
import { chargerInfo } from "../main.js";
import { chargerInfo } from "./charger.js";

const router = express.Router();

Expand Down
21 changes: 10 additions & 11 deletions src/main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,30 +6,29 @@ import { getValidCredentials } from './auth.js';

const port = config.port;
const app = express();
const token = await getValidCredentials();

let token = await getValidCredentials();

if (!token) {
throw new Error('Could not get valid credentials');
}

axios.interceptors.request.use(async (config) => {
config.headers.Authorization = `Bearer ${token?.access_token}`;
// Check if the token is still valid, if not, get a new one
if (token.expires_at < Date.now()) {
token = await getValidCredentials();
if (!token) {
throw new Error('Could not get valid credentials');
}
}
config.headers.Authorization = `Bearer ${token.access_token}`;
return config;
});

const chargerData = (await axios.get(`${config.ampecoApiUrl}/personal/charge-points`)).data.data[0];

const chargerInfo = {
chargerId: chargerData.id,
evseId: chargerData.evses[0].id
}

app.use(express.json());

app.use("/charger", chargerRouter);

app.listen(port, () => {
console.info(`Server is running on http://localhost:${port}`);
});

export { chargerInfo };

0 comments on commit 98aa382

Please sign in to comment.