README
type-graph-orm
Simple integration between TypeORM and GraphQL.js.
import * as GraphORM from 'type-graph-orm'
import {
Column,
Field,
Int,
ManyToOne,
OneToMany,
PrimaryGeneratedColumn,
String,
} from 'typeorm'
import { graphql } from 'graphql'
// Define TypeORM entities
@GraphORM.DatabaseObjectType({
views: [{
// API users can directly query `users` field via this *view*.
isDirectView: true,
name: 'users'
}]
})
export class User {
@PrimaryGeneratedColumn()
public id: number
@Column()
public name: string
@Column()
public age: number
@OneToMany(() => Post, post => post.user)
public posts: Post[]
}
@GraphORM.DatabaseObjectType()
class Post {
@PrimaryGeneratedColumn()
public id: number
@Column()
public title: string
@ManyToOne(() => User, user => user.posts)
public user: User
}
// Create executable schema
const schema = await buildExecutableSchema({
entities: [
User,
Post,
],
})
// Simple query
const result = await graphql(schema, `
query {
users {
id
name
age
posts {
id
title
}
}
}`
)
// Complex filters
const result = await graphql(schema, `
query {
users(where: {name: "Foo"}) {
id
age
posts(where: {id: 2}) {
title
}
}
}`
)
To run tests
Create .env
file at the project root and fill it with database information.
TEST_DB_HOST=localhost
TEST_DB_TYPE=mysql
TEST_DB_NAME=test
TEST_DB_USERNAME=root
TEST_DB_PASSWORD=mypassword
TEST_DB_PORT=3316
If you want, you can run a Docker container of MySQL for test based on .env
file.
docker-compose up -d
Now you can run tests.
yarn test
Notes
Implementation is now at experimental stage. It's currently tested on the simplest cases.