Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
230 changes: 226 additions & 4 deletions script/seed.js

Large diffs are not rendered by default.

17 changes: 17 additions & 0 deletions server/api/blogposts.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
const router = require('express').Router()
const { models: { BlogPost, User }} = require('../db')
const { verifyAdmin, verifyToken } = require('./security')
module.exports = router

router.get('/', async(req, res, next) => {
try{
const blogPosts = await BlogPost.findAll({
include: [{model: User,
as: 'authors'}],
attributes: [title]

})
} catch(err){
next(err)
}
})
6 changes: 3 additions & 3 deletions server/api/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@ module.exports = router


router.use('/users', require('./users'))
//router.use('/blogposts', require('./blogposts'))
//router.use('/tags', require('./tags'))
//router.use('./comments', require('./comments'))
// router.use('/blogposts', require('./blogposts'))
// router.use('/tags', require('./tags'))
// router.use('./comments', require('./comments'))

router.use((req, res, next) => {
const error = new Error('Not Found')
Expand Down
23 changes: 22 additions & 1 deletion server/api/users.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
const router = require('express').Router()
const { models: { User }} = require('../db')
const { models: { User, BlogPost, Author } } = require('../db')
const { verifyAdmin, verifyToken } = require('./security')
module.exports = router

Expand Down Expand Up @@ -28,6 +28,27 @@ router.get('/profile', verifyToken, async (req, res, next) => {
}
})

router.get('/authors', async (req, res, next) => {
try {
console.log('users route entry')
const authors = await Author.findAll({
// explicitly select only the id and username fields - even though
// users' passwords are encrypted, it won't help if we just
// send everything to anyone who asks!
attributes: ['userId'],
include: [{ model: User }]
})

// const authors = await User.findAll({
// include: [{ model: 'authors' }]
// })

res.json(authors)
} catch (err) {
next(err)
}
})


// '/authors' -- accessing the through table, not the users table

Expand Down
36 changes: 30 additions & 6 deletions server/db/index.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
//this is the access point for all things database related!

const db = require('./db')

const Sequelize = require('sequelize')
const User = require('./models/User')
const BlogPost = require('./models/BlogPost')
const Comment = require('./models/Comment')
Expand All @@ -15,11 +15,33 @@ Comment.belongsTo(User);
BlogPost.hasMany(Comment, {foreignKey: "blogPostId"})
Comment.belongsTo(BlogPost);

User.belongsToMany(BlogPost, {through: "authors"})
BlogPost.belongsToMany(User, {through: "authors"})
/*
// The Super Many-to-Many relationship
User.belongsToMany(Profile, { through: Grant });
Profile.belongsToMany(User, { through: Grant });
User.hasMany(Grant);
Grant.belongsTo(User);
Profile.hasMany(Grant);
Grant.belongsTo(Profile);
*/

const Author = db.define('authors', {}, { timestamps: false });
User.belongsToMany(BlogPost, {through: Author})
BlogPost.belongsToMany(User, {through: Author})
User.hasMany(Author)
Author.belongsTo(User)
BlogPost.hasMany(Author)
Author.belongsTo(BlogPost)
// User.belongsToMany(BlogPost, {through: "authors"})
// BlogPost.belongsToMany(User, {through: "authors"})


const Stack = db.define('stacks', {}, { timestamps: false });
User.belongsToMany(BlogPost, {through: Stack})
BlogPost.belongsToMany(User, {through: Stack})

User.belongsToMany(BlogPost, {through: "stacks"})
BlogPost.belongsToMany(User, {through: "stacks"})
// User.belongsToMany(BlogPost, {through: "stacks"})
// BlogPost.belongsToMany(User, {through: "stacks"})

Tag.belongsToMany(BlogPost, {through: "blogPost_tags"})
BlogPost.belongsToMany(Tag, {through: "blogPost_tags"})
Expand All @@ -37,6 +59,8 @@ module.exports = {
BlogPost,
Comment,
Subscription,
Tag
Tag,
Author,
// Stack
},
}
3 changes: 3 additions & 0 deletions server/db/models/BlogPost.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,9 @@ const BlogPost = db.define('blogPost', {
},
image: {
type: Sequelize.TEXT,
},
summary: {
type: Sequelize.TEXT,
}
})

Expand Down
3 changes: 3 additions & 0 deletions server/db/models/User.js
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,9 @@ const User = db.define('user', {
},
bio: {
type: Sequelize.TEXT,
},
pronouns: {
type: Sequelize.STRING,
}
})

Expand Down