@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.
- package/oclif.manifest.json +1 -1
- package/package.json +1 -1
- package/src/commands/cm/export-to-csv.js +8 -2
- package/src/util/index.js +15 -2
package/oclif.manifest.json
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":"0.1.0-beta.
|
|
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.
|
|
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
|
-
|
|
28
|
-
|
|
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
|
}
|