Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Iss1019feat #1030

Merged
merged 21 commits into from
Feb 19, 2022
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
648e3e4
[FEAT] create the scraper in the getEuropeVariants.js file, modify th…
yosoycentli Jan 11, 2022
69e948a
[FEAT] create the scraper in the getEuropeVariants.js file, modify th…
yosoycentli Jan 11, 2022
51095ca
[MODIFY] Rename the getEuropeVariants to --> getVariants
yosoycentli Jan 12, 2022
c88a70a
[MODIFY] Add the line 22 variants to the json
yosoycentli Jan 12, 2022
12611a6
[MODIFY] change the values of keys.variants in the line 15 and 22
yosoycentli Jan 12, 2022
89d6cb2
[ADD/MODIFY] add the instance of the variant.js file and modify the g…
yosoycentli Jan 12, 2022
2dc3beb
[MODIFY] change a several files in order to connect the variant scrap…
yosoycentli Jan 13, 2022
ac42848
[MODIFY] now the scraper works and return the data in the correct format
yosoycentli Jan 14, 2022
614077c
[MODIFY] remove the parameters yearWeek and variant from router.get i…
yosoycentli Jan 17, 2022
5d133ed
[MODIFY] add test for the getVariants.js scraper and remove console.l…
yosoycentli Jan 17, 2022
2fb8e42
[MODIFY] add swagger documentation
yosoycentli Jan 18, 2022
77816d7
[MODIFY] fix swagger documentation
yosoycentli Jan 18, 2022
14ebd0e
Merge branch 'master' into iss1019feat
ebwinters Jan 19, 2022
c9c2f11
[MODIFY] fix eslint style problems
yosoycentli Jan 19, 2022
3478e5b
Merge branch 'iss1019feat' of github.com:yosoycentli/API into iss1019…
yosoycentli Jan 19, 2022
aecddba
Merge branch 'master' into iss1019feat
yosoycentli Jan 20, 2022
46bfc6a
[MODIFY] I commented the lines 2-5 in api_influenza.spec.js file to f…
yosoycentli Jan 25, 2022
e2a66aa
[MODIFY] I change the --timeout value from 200000 to 300000 for the '…
yosoycentli Feb 14, 2022
67b85e2
Merge branch 'master' into iss1019feat
ebwinters Feb 14, 2022
7442e60
[MODIFY] Put back the var in line 57 in order to get a right eslint p…
yosoycentli Feb 14, 2022
a4be9b4
Merge branch 'iss1019feat' of github.com:yosoycentli/API into iss1019…
yosoycentli Feb 14, 2022
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
1 change: 1 addition & 0 deletions config/config.keys.json
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
"vaccine_coverage": "covidapi:vaccine_coverage",
"vaccine_state_coverage": "covidapi:vaccine_state_coverage",
"therapeutics": "covidapi:therapeutics",
"variants":"covidapi:variants",
"influenza_ILINET": "influenza:ILINET",
"influenza_USPHL": "influenza:USPHL",
"influenza_USCL": "influenza:USCL"
Expand Down
2 changes: 2 additions & 0 deletions config/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,8 @@ config.therapeuticsInterval = process.env.THERAPEUTICS_INTERVAL || 864e5;
config.ebolaInterval = process.env.EBOLA_INTERVAL || 864e5;
// eslint-disable-next-line camelcase
config.cdcInterval = process.env.CDC_INTERVAL || 864e5;
// eslint-disable-next-line camelcase
config.variantInterval = process.env.VARIANT_INTERVAL || 864e5;

// SENTRY KEY (ONLY FOR PRODUCTION)
// eslint-disable-next-line camelcase
Expand Down
173 changes: 61 additions & 112 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

5 changes: 5 additions & 0 deletions routes/instances.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ const appleData = require('../scrapers/covid-19/appleMobilityData');
const govData = require('../scrapers/covid-19/govScrapers/getGovData');
const { getVaccineData, getVaccineCoverageData, getVaccineStateCoverageData } = require('../scrapers/covid-19/getVaccine');
const getTherapeuticsData = require('../scrapers/covid-19/getTherapeutics');
const variantsData = require('../scrapers/covid-19/getVariants');
const getCDCDInfluenzaData = require('../scrapers/influenza/getCDC');

// KEYS
Expand Down Expand Up @@ -72,6 +73,10 @@ module.exports = {
await getTherapeuticsData(keys, redis);
logger.info('Finished Therapeutics scraping!');
},
executeScraperVariants: async () => {
await variantsData(keys, redis);
logger.info('Finished Variants scraping!');
},
excecuteScraperInfluenza: async () => {
await getCDCDInfluenzaData(keys, redis);
logger.info('Finished CDC Influenza scraping!');
Expand Down
41 changes: 41 additions & 0 deletions routes/v3/covid-19/apiVariants.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
// *from here* This model comes from apiGov.js:

// eslint-disable-next-line new-cap
const router = require('express').Router();

const nameUtils = require('../../../utils/nameUtils');
const { wordToBoolean } = require('../../../utils/stringUtils');
const { redis, keys } = require('../../instances');

router.get('/v3/covid-19/variants/countries/:country?', async (req, res) => {
const { allowNull } = req.query;
const { country: countryName, yearWeek, variant } = req.params;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't see the yearWeek and variant parameters being used

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I put them there since I wanted the API had to have these parameters, but I think it's better to remove them and later when they're created added again.

if (countryName) {
const standardizedCountryName = nameUtils.getCountryData(countryName.trim()).country || countryName.trim();
const data = JSON.parse(await redis.hget(keys.variants, standardizedCountryName));
if (data) {
res.send(!wordToBoolean(allowNull) ? nameUtils.transformNull(data) : data);
} else {
res.status(404).send({ message: `Country '${standardizedCountryName}' not found or no data found for country` });
}
} else {
res.send((await redis.hkeys(keys.variants)).sort());
}
});

module.exports = router;

// *to here*

// Take this code below as an example:
// router.get('/v3/covid-19/countries/:query', async (req, res) => {
// const { yesterday, twoDaysAgo, strict, allowNull } = req.query;
// const { query } = req.params;
// let countries = JSON.parse(await redis.get(wordToBoolean(yesterday) ? keys.yesterday_countries : wordToBoolean(twoDaysAgo) ? keys.twoDaysAgo_countries : keys.countries))
// .filter(country => country.country.toLowerCase() !== 'world').map(fixApostrophe);
// countries = splitQuery(query)
// .map(country => nameUtils.getWorldometersData(countries, country, strict !== 'false'))
// .filter(value => value).map(country => !wordToBoolean(allowNull) ? nameUtils.transformNull(country) : country);
// if (countries.length > 0) res.send(countries.length === 1 ? countries[0] : countries);
// else res.status(404).send({ message: 'Country not found or doesn\'t have any cases' });
// });
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove once ready to publish draft

Loading