chore: Introduce app info converter and use JSON for info files

This commit is contained in:
Faruk AYDIN
2021-10-20 13:56:41 +02:00
committed by Ali BARIN
parent 2293c939e7
commit a7582a4503
9 changed files with 33 additions and 42 deletions

View File

@@ -1,10 +1,7 @@
import appInfoType from '../../types/app-info';
import appConfig from '../../config/app';
const appInfo: appInfoType = {
{
"name": "Flickr",
"key": "flickr",
"iconUrl": `${appConfig.baseUrl}/apps/flickr/assets/favicon.svg`,
"iconUrl": "{BASE_URL}/apps/flickr/assets/favicon.svg",
"docUrl": "https://automatisch.io/docs/flickr",
"primaryColor": "000000",
"fields": [
@@ -116,5 +113,3 @@ const appInfo: appInfoType = {
}
]
}
export default appInfo;

View File

@@ -1,10 +1,7 @@
import appInfoType from '../../types/app-info';
import appConfig from '../../config/app';
const appInfo: appInfoType = {
{
"name": "Twitch",
"key": "twitch",
"iconUrl": `${appConfig.baseUrl}/apps/twitch/assets/favicon.svg`,
"iconUrl": "{BASE_URL}/apps/twitch/assets/favicon.svg",
"docUrl": "https://automatisch.io/docs/twitch",
"primaryColor": "6441a5",
"fields": [
@@ -46,5 +43,3 @@ const appInfo: appInfoType = {
}
]
}
export default appInfo;

View File

@@ -1,10 +1,7 @@
import appInfoType from '../../types/app-info';
import appConfig from '../../config/app';
const appInfo: appInfoType = {
{
"name": "Twitter",
"key": "twitter",
"iconUrl": `${appConfig.baseUrl}/apps/twitter/assets/favicon.svg`,
"iconUrl": "{BASE_URL}/apps/twitter/assets/favicon.svg",
"docUrl": "https://automatisch.io/docs/twitter",
"primaryColor": "2DAAE1",
"fields": [
@@ -116,5 +113,3 @@ const appInfo: appInfoType = {
}
]
}
export default appInfo;

View File

@@ -10,7 +10,7 @@ type Params = {
data: object
}
const createConnectionResolver = async (params: Params, req: RequestWithCurrentUser) => {
const app = await App.findOneByKey(params.key);
const app = App.findOneByKey(params.key);
const connection = await Connection.query().insert({
key: params.key,
data: params.data,

View File

@@ -9,7 +9,7 @@ type Params = {
}
const getAppConnectionsResolver = async (params: Params, req: RequestWithCurrentUser) => {
const app = await App.findOneByKey(params.key);
const app = App.findOneByKey(params.key);
const connections = await Connection.query()
.where({ user_id: req.currentUser.id, key: params.key })

View File

@@ -14,7 +14,7 @@ const getAppResolver = async (params: Params, req: RequestWithCurrentUser) => {
throw new Error('No key provided.')
}
const app = await App.findOneByKey(params.key);
const app = App.findOneByKey(params.key);
if (req.currentUser?.id) {
const connections = await Connection.query()

View File

@@ -9,7 +9,7 @@ type Params = {
}
const getConnectedAppsResolver = async (params: Params, req: RequestWithCurrentUser) => {
let apps = await App.findAll(params.name)
let apps = App.findAll(params.name)
const connections = await Connection.query()
.select('connections.key')

View File

@@ -0,0 +1,11 @@
import AppInfoType from '../types/app-info';
import appConfig from '../config/app';
const appInfoConverter = (rawAppData: string) => {
const computedRawData = rawAppData.replace('{BASE_URL}', appConfig.baseUrl);
const computedJSONData: AppInfoType = JSON.parse(computedRawData)
return computedJSONData;
}
export default appInfoConverter;

View File

@@ -1,31 +1,26 @@
import fs from 'fs';
import appInfoConverter from '../helpers/app-info-converter';
class App {
static folderPath = __dirname + '/../apps';
static list = fs.readdirSync(this.folderPath);
static async findAll(name?: string): Promise<object[]> {
let appList;
static findAll(name?: string): object[] {
if(!name) return this.list.map((name) => this.findOneByName(name));
if(!name) {
appList = this.list.map(async (name) => await this.findOneByName(name));
} else {
appList = this.list
.filter((app) => app.includes(name.toLowerCase()))
.map(async (name) => await this.findOneByName(name));
}
return Promise.all(appList)
return this.list
.filter((app) => app.includes(name.toLowerCase()))
.map((name) => this.findOneByName(name));
}
static async findOneByName(name: string): Promise<object> {
const rawAppData = (await import(`../apps/${name}/info`)).default;
return rawAppData;
static findOneByName(name: string): object {
const rawAppData = fs.readFileSync(this.folderPath + `/${name}/info.json`, 'utf-8');
return appInfoConverter(rawAppData);
}
static async findOneByKey(key: string): Promise<object> {
const rawAppData = (await import(`../apps/${key}/info`)).default;
return rawAppData;
static findOneByKey(key: string): object {
const rawAppData = fs.readFileSync(this.folderPath + `/${key}/info.json`, 'utf-8');
return appInfoConverter(rawAppData);
}
}