2015-03-07 17:50:26 +01:00
|
|
|
notes = share.notes = new Mongo.Collection 'notes'
|
|
|
|
|
2015-03-10 09:55:08 +01:00
|
|
|
if !Meteor.settings.public?.enableAPI? then return
|
2015-03-07 17:50:26 +01:00
|
|
|
|
|
|
|
console.log 'RESTful HTTP API enabled'
|
|
|
|
|
2015-03-09 18:03:25 +01:00
|
|
|
apiKeyToUser = (key) ->
|
|
|
|
if key? and key != "" then Meteor.users.findOne apiKey: key
|
2015-03-07 17:50:26 +01:00
|
|
|
respond = (res, code, obj) ->
|
|
|
|
res.writeHead code, 'Content-Type': 'application/json'
|
|
|
|
res.end JSON.stringify obj
|
|
|
|
|
|
|
|
Router.route '/api/:key', where: 'server'
|
2015-03-09 18:03:25 +01:00
|
|
|
# GET NOTES
|
2015-03-07 17:50:26 +01:00
|
|
|
.get ->
|
|
|
|
user = apiKeyToUser @params.key
|
|
|
|
if !user
|
|
|
|
respond @response, 400, error: 'invalid api key'
|
|
|
|
else
|
|
|
|
respond @response, 200, notes.find(
|
|
|
|
{ userId: user._id, archived: no },
|
|
|
|
{ fields: { archived: 0, userId: 0 }, sort: { date: 1 }}).fetch()
|
2015-03-09 16:29:14 +01:00
|
|
|
# POST - inserts new note
|
|
|
|
.post ->
|
|
|
|
user = apiKeyToUser @params.key
|
|
|
|
if !user
|
|
|
|
respond @response, 400, error: 'invalid api key'
|
|
|
|
else
|
|
|
|
if @request.body.date? and @request.body.date isnt false
|
|
|
|
@request.body.date = moment(@request.body.date, @request.body.dateformat || user.dateformat).unix()
|
|
|
|
else @request.body.date = no
|
|
|
|
toInsert =
|
|
|
|
userId: user._id
|
|
|
|
title: @request.body.title
|
|
|
|
date: @request.body.date
|
|
|
|
content: @request.body.content || ""
|
|
|
|
archived: @request.body.archived || no
|
|
|
|
if @request.body.title? then notes.insert toInsert, (e,i) =>
|
|
|
|
respond @response, (if e then 500 else 200), if e then { error: e } else { inserted: i }
|
|
|
|
else respond @response, 400, { error: '"title" field required to insert note into database' }
|
2015-03-07 17:50:26 +01:00
|
|
|
|
2015-03-09 16:29:14 +01:00
|
|
|
# GET archive
|
2015-03-07 17:50:26 +01:00
|
|
|
Router.route '/api/:key/archived', where: 'server'
|
|
|
|
.get ->
|
|
|
|
user = apiKeyToUser @params.key
|
|
|
|
if !user
|
|
|
|
respond @response, 400, error: 'invalid api key'
|
|
|
|
else
|
|
|
|
respond @response, 200, notes.find(
|
|
|
|
{ userId: user._id, archived: yes },
|
|
|
|
{ fields: { archived: 0, userId: 0 }, sort: { date: 1 }}).fetch()
|
|
|
|
|
|
|
|
# BACKUP
|
|
|
|
Router.route '/api/:key/backup', where: 'server'
|
|
|
|
.get ->
|
|
|
|
user = apiKeyToUser @params.key
|
|
|
|
if !user
|
|
|
|
respond @response, 400, error: 'invalid api key'
|
|
|
|
else
|
|
|
|
respond @response, 200, notes.find(userId: user._id).fetch()
|
|
|
|
|
|
|
|
# RESTORE to be implemented
|
|
|
|
|
2015-03-09 16:29:14 +01:00
|
|
|
Router.route '/api/:key/:id', where: 'server'
|
|
|
|
# DELETE NOTE
|
2015-03-07 17:50:26 +01:00
|
|
|
.delete ->
|
|
|
|
user = apiKeyToUser @params.key
|
|
|
|
if !user
|
|
|
|
respond @response, 400, error: 'invalid api key'
|
|
|
|
else
|
2015-03-09 16:29:14 +01:00
|
|
|
notes.remove @params.id, (e,d) =>
|
|
|
|
if e then respond @response, 400, { error: e }
|
|
|
|
else respond @response, 200, { deleted: d }
|