@contentstack/cli-cm-export-to-csv 0.1.0-beta.2 → 0.1.0-beta.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":"0.1.0-beta.2","commands":{"cm:export-to-csv":{"id":"cm:export-to-csv","description":"Export entries or organization users to csv using this command\n","pluginName":"@contentstack/cli-cm-export-to-csv","pluginType":"core","aliases":[],"flags":{},"args":[]}}}
1
+ {"version":"0.1.0-beta.3","commands":{"cm:export-to-csv":{"id":"cm:export-to-csv","description":"Export entries or organization users to csv using this command\n","pluginName":"@contentstack/cli-cm-export-to-csv","pluginType":"core","aliases":[],"flags":{},"args":[]}}}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@contentstack/cli-cm-export-to-csv",
3
3
  "description": "Export entities to csv",
4
- "version": "0.1.0-beta.2",
4
+ "version": "0.1.0-beta.3",
5
5
  "author": "Abhinav Gupta @abhinav-from-contentstack",
6
6
  "bugs": "https://github.com/contentstack/cli/issues",
7
7
  "dependencies": {
@@ -24,8 +24,14 @@ class ExportToCsvCommand extends Command {
24
24
  const environments = await util.getEnvironments(this.managementAPIClient, stack.apiKey) // fetch environments, because in publish details only env uid are available and we need env names
25
25
  while(contentTypes.length > 0) {
26
26
  let contentType = contentTypes.shift()
27
- let entries = await util.getEntries(this.managementAPIClient, stack.apiKey, contentType, language.code) // fetch entries
28
- let flatEntries = util.cleanEntries(entries.items, language.code, environments, contentType); // clean entries to be wderitten to file
27
+
28
+ const entriesCount = await util.getEntriesCount(this.managementAPIClient, stack.apiKey, contentType, language.code);
29
+ let flatEntries = [];
30
+ for (let index = 0; index < entriesCount / 100; index++) {
31
+ const entriesResult = await util.getEntries(this.managementAPIClient, stack.apiKey, contentType, language.code, index);
32
+ const flatEntriesResult = util.cleanEntries(entriesResult.items, language.code, environments, contentType);
33
+ flatEntries = flatEntries.concat(flatEntriesResult);
34
+ }
29
35
  // let dateTime = util.getDateTime()
30
36
  // let fileName = `${contentType}_${language.code}_entries_export_${dateTime}.csv`
31
37
  let fileName = `${stack.name}_${contentType}_${language.code}_entries_export.csv`
package/src/util/index.js CHANGED
@@ -173,18 +173,30 @@ function getLanguages(managementAPIClient, stackApiKey) {
173
173
  })
174
174
  }
175
175
 
176
- function getEntries(managementAPIClient, stackApiKey, contentType, language) {
176
+ function getEntries(managementAPIClient, stackApiKey, contentType, language, skip) {
177
177
  return new Promise(resolve => {
178
178
  managementAPIClient
179
179
  .stack({api_key: stackApiKey})
180
180
  .contentType(contentType)
181
181
  .entry()
182
- .query({include_publish_details: true, locale: language})
182
+ .query({include_publish_details: true, locale: language, skip: skip * 100})
183
183
  .find()
184
184
  .then(entries => resolve(entries))
185
185
  })
186
186
  }
187
187
 
188
+ function getEntriesCount(managementAPIClient, stackApiKey, contentType, language) {
189
+ return new Promise((resolve) => {
190
+ managementAPIClient
191
+ .stack({ api_key: stackApiKey })
192
+ .contentType(contentType)
193
+ .entry()
194
+ .query({ include_publish_details: true, locale: language })
195
+ .count()
196
+ .then((entriesData) => resolve(entriesData.entries));
197
+ });
198
+ }
199
+
188
200
  function getEnvironments(managementAPIClient, stackApiKey) {
189
201
  let result = {}
190
202
  return managementAPIClient.stack({api_key: stackApiKey}).environment().query().find().then(environments => {
@@ -413,4 +425,5 @@ module.exports = {
413
425
  getOrganizationsWhereUserIsAdmin: getOrganizationsWhereUserIsAdmin,
414
426
  kebabize: kebabize,
415
427
  flatten: flatten,
428
+ getEntriesCount: getEntriesCount,
416
429
  }