aboutsummaryrefslogtreecommitdiffhomepage
path: root/routes/api/v1
diff options
context:
space:
mode:
authorChocobozzz <florian.bigard@gmail.com>2015-11-06 17:34:15 +0100
committerChocobozzz <florian.bigard@gmail.com>2015-11-06 17:34:31 +0100
commitf5a60a5138135a3412dfbcfd6e564f7aa47a55c2 (patch)
tree2516f410a33792f9112b4b4253929e5292908a3f /routes/api/v1
parenta6fa7ac141637a5026388157084c439f920c5ff1 (diff)
downloadPeerTube-f5a60a5138135a3412dfbcfd6e564f7aa47a55c2.tar.gz
PeerTube-f5a60a5138135a3412dfbcfd6e564f7aa47a55c2.tar.zst
PeerTube-f5a60a5138135a3412dfbcfd6e564f7aa47a55c2.zip
Add API versionning
Diffstat (limited to 'routes/api/v1')
-rw-r--r--routes/api/v1/index.js10
-rw-r--r--routes/api/v1/pods.js38
-rw-r--r--routes/api/v1/remoteVideos.js29
-rw-r--r--routes/api/v1/videos.js61
4 files changed, 138 insertions, 0 deletions
diff --git a/routes/api/v1/index.js b/routes/api/v1/index.js
new file mode 100644
index 000000000..9a4ec8438
--- /dev/null
+++ b/routes/api/v1/index.js
@@ -0,0 +1,10 @@
1;(function () {
2 'use strict'
3
4 var api = {}
5 api.videos = require('./videos')
6 api.remoteVideos = require('./remoteVideos')
7 api.pods = require('./pods')
8
9 module.exports = api
10})()
diff --git a/routes/api/v1/pods.js b/routes/api/v1/pods.js
new file mode 100644
index 000000000..961388fcb
--- /dev/null
+++ b/routes/api/v1/pods.js
@@ -0,0 +1,38 @@
1;(function () {
2 'use strict'
3
4 var express = require('express')
5 var router = express.Router()
6 var middleware = require('../../../middlewares')
7 var pods = require('../../../src/pods')
8
9 function listPods (req, res, next) {
10 pods.list(function (err, pods_list) {
11 if (err) return next(err)
12
13 res.json(pods_list)
14 })
15 }
16
17 function addPods (req, res, next) {
18 pods.add(req.body.data, function (err, json) {
19 if (err) return next(err)
20
21 res.json(json)
22 })
23 }
24
25 function makeFriends (req, res, next) {
26 pods.makeFriends(function (err) {
27 if (err) return next(err)
28
29 res.sendStatus(204)
30 })
31 }
32
33 router.get('/', middleware.cache(false), listPods)
34 router.get('/makefriends', middleware.cache(false), makeFriends)
35 router.post('/', middleware.cache(false), addPods)
36
37 module.exports = router
38})()
diff --git a/routes/api/v1/remoteVideos.js b/routes/api/v1/remoteVideos.js
new file mode 100644
index 000000000..88b8e879b
--- /dev/null
+++ b/routes/api/v1/remoteVideos.js
@@ -0,0 +1,29 @@
1;(function () {
2 'use strict'
3
4 var express = require('express')
5 var router = express.Router()
6 var middleware = require('../../../middlewares')
7 var videos = require('../../../src/videos')
8
9 function addRemoteVideos (req, res, next) {
10 videos.addRemote(req.body.data, function (err, video) {
11 if (err) return next(err)
12
13 res.json(video)
14 })
15 }
16
17 function removeRemoteVideo (req, res, next) {
18 videos.removeRemote(req.body.signature.url, req.body.data.magnetUri, function (err) {
19 if (err) return next(err)
20
21 res.status(204)
22 })
23 }
24
25 router.post('/add', middleware.cache(false), middleware.decryptBody, addRemoteVideos)
26 router.post('/remove', middleware.cache(false), middleware.decryptBody, removeRemoteVideo)
27
28 module.exports = router
29})()
diff --git a/routes/api/v1/videos.js b/routes/api/v1/videos.js
new file mode 100644
index 000000000..246620ac6
--- /dev/null
+++ b/routes/api/v1/videos.js
@@ -0,0 +1,61 @@
1;(function () {
2 'use strict'
3
4 var express = require('express')
5 var router = express.Router()
6 var middleware = require('../../../middlewares')
7 var videos = require('../../../src/videos')
8
9 function listVideos (req, res, next) {
10 videos.list(function (err, videos_list) {
11 if (err) return next(err)
12
13 res.json(videos_list)
14 })
15 }
16
17 function searchVideos (req, res, next) {
18 videos.search(req.params.name, function (err, videos_list) {
19 if (err) return next(err)
20
21 res.json(videos_list)
22 })
23 }
24
25 function addVideos (req, res, next) {
26 videos.add({ video: req.files.input_video, data: req.body }, function (err) {
27 if (err) return next(err)
28
29 // TODO : include Location of the new video
30 res.sendStatus(201)
31 })
32 }
33
34 function getVideos (req, res, next) {
35 videos.get(req.params.id, function (err, video) {
36 if (err) return next(err)
37
38 if (video === null) {
39 return res.sendStatus(404)
40 }
41
42 res.json(video)
43 })
44 }
45
46 function removeVideo (req, res, next) {
47 videos.remove(req.params.id, function (err) {
48 if (err) return next(err)
49
50 res.sendStatus(204)
51 })
52 }
53
54 router.get('/', middleware.cache(false), listVideos)
55 router.post('/', middleware.cache(false), addVideos)
56 router.get('/search/:name', middleware.cache(false), searchVideos)
57 router.get('/:id', middleware.cache(false), getVideos)
58 router.delete('/:id', middleware.cache(false), removeVideo)
59
60 module.exports = router
61})()