mirror of
https://github.com/koodiklinikka/koodiklinikka.fi-api.git
synced 2026-03-10 15:02:39 +00:00
Refactored feeds in to services
Changed members route to use the GitHub service for data fetching
This commit is contained in:
@@ -1,10 +1,9 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
var request = require('superagent');
|
|
||||||
var cache = require('apicache').middleware;
|
var cache = require('apicache').middleware;
|
||||||
var Promise = require('bluebird');
|
var Promise = require('bluebird');
|
||||||
var twitter = require('../feeds/twitter');
|
var twitter = require('../services/twitter');
|
||||||
var github = require('../feeds/github');
|
var github = require('../services/github');
|
||||||
|
|
||||||
module.exports = function (app) {
|
module.exports = function (app) {
|
||||||
/*
|
/*
|
||||||
|
|||||||
@@ -1,28 +1,19 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
var request = require('superagent');
|
var github = require('../services/github');
|
||||||
var cache = require('apicache').middleware;
|
var cache = require('apicache').middleware;
|
||||||
|
|
||||||
var config = require('../lib/config');
|
|
||||||
|
|
||||||
module.exports = function (app) {
|
module.exports = function (app) {
|
||||||
/*
|
/*
|
||||||
* POST /members
|
* POST /members
|
||||||
* Endpoint for fetching GitHub org members
|
* Endpoint for fetching GitHub org public members
|
||||||
*/
|
*/
|
||||||
|
|
||||||
app.get('/members', cache('3 hours'), function(req, res, next) {
|
app.get('/members', cache('3 hours'), function(req, res, next) {
|
||||||
request
|
github.getMembers().then(function(data) {
|
||||||
.get('https://api.github.com/orgs/koodiklinikka/public_members')
|
res.status(200).send(data);
|
||||||
.set('Authorization', 'token ' + config.github.token)
|
}, function(error) {
|
||||||
.end(function(error, response){
|
next(error);
|
||||||
if(error) {
|
|
||||||
return next(error);
|
|
||||||
}
|
|
||||||
req.apicacheGroup = response.body;
|
|
||||||
res.status(200).send(response.body);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -18,6 +18,23 @@ module.exports = {
|
|||||||
reject(error);
|
reject(error);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
resolve(response.body);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* Fetch all the public members of the GitHub organization
|
||||||
|
*/
|
||||||
|
getMembers: function() {
|
||||||
|
return new Promise(function(resolve, reject) {
|
||||||
|
request
|
||||||
|
.get('https://api.github.com/orgs/koodiklinikka/public_members')
|
||||||
|
.set('Authorization', 'token ' + config.github.token)
|
||||||
|
.end(function(error, response){
|
||||||
|
if (error) {
|
||||||
|
reject(error);
|
||||||
|
}
|
||||||
|
|
||||||
resolve(response.body);
|
resolve(response.body);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
Reference in New Issue
Block a user