feat: Create testConnection graphQL query
This commit is contained in:
@@ -38,4 +38,9 @@ export default class Twitter {
|
|||||||
screenName: verifiedCredentials.screenName
|
screenName: verifiedCredentials.screenName
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async isStillVerified() {
|
||||||
|
const userData = await this.client.currentUser();
|
||||||
|
return userData.id ? true : false
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
31
packages/backend/src/graphql/queries/test-connection.ts
Normal file
31
packages/backend/src/graphql/queries/test-connection.ts
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
import { GraphQLString, GraphQLNonNull, GraphQLBoolean } from 'graphql';
|
||||||
|
import Connection from '../../models/connection';
|
||||||
|
import RequestWithCurrentUser from '../../types/express/request-with-current-user';
|
||||||
|
|
||||||
|
type Params = {
|
||||||
|
id: string,
|
||||||
|
data: object
|
||||||
|
}
|
||||||
|
const testConnectionResolver = async (params: Params, req: RequestWithCurrentUser) => {
|
||||||
|
let connection = await Connection.query().findOne({
|
||||||
|
user_id: req.currentUser.id,
|
||||||
|
id: params.id
|
||||||
|
})
|
||||||
|
|
||||||
|
const appClass = (await import(`../../apps/${connection.key}`)).default;
|
||||||
|
|
||||||
|
const appInstance = new appClass(connection.data)
|
||||||
|
const isStillVerified = await appInstance.isStillVerified();
|
||||||
|
|
||||||
|
return isStillVerified;
|
||||||
|
}
|
||||||
|
|
||||||
|
const testConnection = {
|
||||||
|
type: GraphQLBoolean,
|
||||||
|
args: {
|
||||||
|
id: { type: GraphQLNonNull(GraphQLString) }
|
||||||
|
},
|
||||||
|
resolve: (_: any, params: Params, req: RequestWithCurrentUser) => testConnectionResolver(params, req)
|
||||||
|
};
|
||||||
|
|
||||||
|
export default testConnection;
|
@@ -3,6 +3,7 @@ import getApps from './queries/get-apps';
|
|||||||
import getApp from './queries/get-app';
|
import getApp from './queries/get-app';
|
||||||
import getConnectedApps from './queries/get-connected-apps';
|
import getConnectedApps from './queries/get-connected-apps';
|
||||||
import getAppConnections from './queries/get-app-connections';
|
import getAppConnections from './queries/get-app-connections';
|
||||||
|
import testConnection from './queries/test-connection';
|
||||||
|
|
||||||
const rootQuery = new GraphQLObjectType({
|
const rootQuery = new GraphQLObjectType({
|
||||||
name: 'Query',
|
name: 'Query',
|
||||||
@@ -10,7 +11,8 @@ const rootQuery = new GraphQLObjectType({
|
|||||||
getApps,
|
getApps,
|
||||||
getApp,
|
getApp,
|
||||||
getConnectedApps,
|
getConnectedApps,
|
||||||
getAppConnections
|
getAppConnections,
|
||||||
|
testConnection
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@@ -5,10 +5,6 @@ export const CREATE_CONNECTION = gql`
|
|||||||
createConnection(key: $key, data: $data) {
|
createConnection(key: $key, data: $data) {
|
||||||
key
|
key
|
||||||
id
|
id
|
||||||
data {
|
|
||||||
consumerKey
|
|
||||||
consumerSecret
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
@@ -6,10 +6,6 @@ export const UPDATE_CONNECTION = gql`
|
|||||||
id
|
id
|
||||||
key
|
key
|
||||||
verified
|
verified
|
||||||
data {
|
|
||||||
consumerKey
|
|
||||||
consumerSecret
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
Reference in New Issue
Block a user