2017-10-25 02:11:28 -07:00
|
|
|
import {
|
2018-02-14 16:00:32 -08:00
|
|
|
IDatasetsGetResponse,
|
2017-10-25 02:11:28 -07:00
|
|
|
IDatasetView,
|
2018-02-14 16:00:32 -08:00
|
|
|
IDatasetViewGetResponse,
|
|
|
|
IReadDatasetsOptionBag
|
2017-10-25 02:11:28 -07:00
|
|
|
} from 'wherehows-web/typings/api/datasets/dataset';
|
2017-09-20 14:25:27 -07:00
|
|
|
import { getHeaders, getJSON } from 'wherehows-web/utils/api/fetcher';
|
2018-02-14 16:00:32 -08:00
|
|
|
import {
|
|
|
|
datasetsCountUrl,
|
|
|
|
datasetsUrl,
|
|
|
|
datasetsUrlRoot,
|
2018-02-14 20:47:26 -08:00
|
|
|
datasetUrlByUrn
|
2018-02-14 16:00:32 -08:00
|
|
|
} from 'wherehows-web/utils/api/datasets/shared';
|
2018-02-25 20:34:38 -08:00
|
|
|
import { encodeUrn } from 'wherehows-web/utils/validators/urn';
|
2017-09-20 14:25:27 -07:00
|
|
|
|
2018-02-14 20:47:26 -08:00
|
|
|
/**
|
|
|
|
* Reads a dataset by urn, in the li format
|
|
|
|
* @param {string} urn
|
|
|
|
* @returns {Promise<IDatasetView>}
|
|
|
|
*/
|
2018-02-25 20:34:38 -08:00
|
|
|
const readDatasetByUrn = async (urn: string = ''): Promise<IDatasetView> => {
|
|
|
|
const { dataset } = await getJSON<Pick<IDatasetViewGetResponse, 'dataset'>>({ url: datasetUrlByUrn(encodeUrn(urn)) });
|
2018-02-14 20:47:26 -08:00
|
|
|
return dataset!;
|
|
|
|
};
|
|
|
|
|
2017-10-25 02:11:28 -07:00
|
|
|
/**
|
2018-02-28 16:31:37 -08:00
|
|
|
* Constructs a url to get a dataset urn given a dataset id
|
2018-02-14 16:00:32 -08:00
|
|
|
* @param {number} id
|
2017-09-20 14:25:27 -07:00
|
|
|
* @return {string}
|
|
|
|
*/
|
2018-02-28 16:31:37 -08:00
|
|
|
const datasetUrnTranslationUrlByUrn = (id: number): string => `${datasetsUrlRoot('v2')}/idtourn/${id}`;
|
2017-09-20 14:25:27 -07:00
|
|
|
|
|
|
|
/**
|
2018-02-28 16:31:37 -08:00
|
|
|
* Translates a dataset id to a dataset urn, using the endpoint at datasetIdTranslationUrlByUrn()
|
|
|
|
* @param {number} id
|
|
|
|
* @return {Promise<string>}
|
2017-09-20 14:25:27 -07:00
|
|
|
*/
|
2018-02-28 16:31:37 -08:00
|
|
|
const datasetIdToUrn = async (id: number) => {
|
|
|
|
const headers = await getHeaders({ url: datasetUrnTranslationUrlByUrn(id) });
|
|
|
|
return headers.get('whUrn');
|
2017-09-20 14:25:27 -07:00
|
|
|
};
|
|
|
|
|
2018-02-14 16:00:32 -08:00
|
|
|
/**
|
|
|
|
* Fetches the datasets for a platform, and prefix and returns the list of datasets in the
|
|
|
|
* response
|
|
|
|
* @param {IReadDatasetsOptionBag} {
|
|
|
|
* platform,
|
|
|
|
* prefix
|
|
|
|
* }
|
|
|
|
* @returns {Promise<IDatasetsGetResponse['elements']>}
|
|
|
|
*/
|
|
|
|
const readDatasets = async ({
|
|
|
|
platform,
|
|
|
|
prefix
|
|
|
|
}: IReadDatasetsOptionBag): Promise<IDatasetsGetResponse['elements']> => {
|
|
|
|
const url = datasetsUrl({ platform, prefix });
|
|
|
|
const response = await getJSON<IDatasetsGetResponse>({ url });
|
|
|
|
|
|
|
|
return response ? [...response.elements] : [];
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the number of datasets, if provided, using the platform and prefix also
|
|
|
|
* @param {Partial<IReadDatasetsOptionBag>} { platform, prefix }
|
|
|
|
* @returns {Promise<number>}
|
|
|
|
*/
|
|
|
|
const readDatasetsCount = async ({ platform, prefix }: Partial<IReadDatasetsOptionBag>): Promise<number> => {
|
|
|
|
const url = datasetsCountUrl({ platform, prefix });
|
|
|
|
return await getJSON<number>({ url });
|
|
|
|
};
|
|
|
|
|
2018-02-28 16:31:37 -08:00
|
|
|
export { readDatasets, readDatasetsCount, readDatasetByUrn, datasetIdToUrn };
|