概述:
我在将产品部署到GCP以及随后通过Node.js v8.12.0进行GCS的过程中实现自动化。此部署过程的开始要求我执行以下操作:
遍历项目文件夹中的文件夹和文件,以找到GCS服务帐户JSON密钥文件。
标识所述密钥文件的位置。
运行导出GOOGLE_APPLICATION_CREDENTIALS =“ / path / to / file / [FILE_NAME] .json”设置位置,以便我可以执行代码以通过节点调用GCS函数。
我尝试通过node.js中的child_process.exec模块执行命令。执行成功,但在备用shell中。
根据google文档,设置 GOOGLE_APPLICATION_CREDENTIALS 变量“ ...仅适用于您当前的Shell会话,因此,如果您打开一个新会话,请再次设置该变量。”
尽管设置时间不多,但我想在部署过程中将其自动化。那么,有没有办法让我在当前Shell中执行此操作?也欢迎其他想法。
以下代码:
const {Storage} = require('@google-cloud/storage');
const storage = new Storage();
var readFileTree = require('read-file-tree');
const prompts = require('prompts');
const find = require('find-file-up');
// var tty = require('tty');
var program = require('commander');
const { exec } = require('child_process');
const chalk = require('chalk');
var gsBuckets = {};
var i = 0;
function findOauthJSON () {
console.log("Finding your service account keys...")
find('fauxfile_1123456ae.json', 'a/b/c', function(err, file) {
if (file !== undefined) {
console.log("Service keys found: ",file);
setOathJSON(file);
} else if (err !== undefined) {
console.log(err);
} else {
console.log("Couldn't find your service account keys. Add to your folders and try again.")
}
});
}
function setOathJSON (file) {
console.log("Setting service key pay to access GCS...");
var command = 'export GOOGLE_APPLICATION_CREDENTIALS=\"'+file+'\"';
exec(command, (err, stdout, stderr) => {
if (err === null) {
console.log("Service key set!");
}
// the *entire* stdout and stderr (buffered)
console.log(`stdout: ${stdout}`);
console.log(`stderr: ${stderr}`);
console.log(`err: ${err}`);
console.log("cmd: "+command);
});
}
function gstoreInfo () {
console.log("Getting cloud storage info...");
storage
.getBuckets()
.then(results => {
const buckets = results[0];
buckets.forEach(bucket => {
gsBuckets["gstoreb"+i] = bucket.name;
console.log("Found bucket: "+bucket.name);
i++;
});
})
.catch(err => {
console.error('ERROR:', err);
});
}
答案 0 :(得分:1)
弄清楚了。 Node惯用库允许您通过实例化的存储对象设置keyFileName路径,如下所示:
const storage = new Storage({
projectId: 'mystorage-bucket-123456',
keyFilename: ''/path/to/keyfile.json''
});
该文档有些隐藏,但是您可以在这里找到它:https://github.com/googleapis/google-cloud-node/blob/master/docs/authentication.md
每次调用存储时,都会传递keyFilename进行身份验证。我使用了与上面相同的代码,并且有效。