我正在尝试使用Design Automation API的v2更改我发布的AppPackage所需的引擎版本。
我尝试过使用Postman和Forge Node Client。我正在使用Forge文档作为参考。
https://forge.autodesk.com/en/docs/design-automation/v2/reference/http/AppPackages( ':ID') - PATCH /
我的凭据是正确的,我有一个有效的令牌,但由于某种原因,我一直收到404 Not Found状态,并显示“AppPackage的名称MyPlugin不属于您。您不能在AppPackage上运行,您不拥有“。此外,当我尝试删除或更新AppPackage时,我收到相同的消息。
这真的很奇怪,因为我绝对拥有这个AppPackage。我使用这些相同的凭据上传它,我可以通过执行GET请求查看我的所有AppPackage来查看它。此外,AppPackage的名称是正确的,我在验证时指定了正确的范围(代码:all)。
为什么Design Automation认为这个AppPackage不属于我,为什么我不能修补,更新或删除它?
更新2014年3月28日:设置资源值仍会导致相同的错误
更新4/2/2019:获取新的上传URL也不起作用。我收到内部服务器错误,说“对象引用未设置为对象的实例”。
const ForgeSDK = require('forge-apis');
const oAuth2TwoLegged = new ForgeSDK.AuthClientTwoLegged(FORGE_CLIENT_ID, FORGE_CLIENT_SECRET, SCOPES);
const appPackageApi = new ForgeSDK.AppPackagesApi();
const getToken = () => {
return oAuth2TwoLegged.authenticate();
};
const getUploadURL = () => {
return appPackageApi.getUploadUrl(oAuth2TwoLegged, oAuth2TwoLegged.getCredentials());
};
const patchPackage = (id, url) => {
const appPack = {
Resource: url,
RequiredEngineVersion: APP_PACKAGE_REQUIRED_ENGINE
};
return appPackageApi.patchAppPackage(id, appPack, oAuth2TwoLegged, oAuth2TwoLegged.getCredentials());
};
(async () => {
try {
const token = await getToken();
const url = await getUploadURL();
const patchPackRes = await patchPackage(APP_PACKAGE_ID, url);
if (patchPackRes.statusCode == 201)
console.log('Patch package succeeded!');
else
console.log('Patch package failed!' + patchPackRes.statusCode);
} catch (ex) {
console.log('Exception :(');
console.log(ex);
}
})();
调用PATCH时,必须设置“Resource”属性。它可以设置为与从GET收到的URL相同的URL,但它必须存在且有效。
这应该工作:
const ForgeSDK = require('forge-apis');
const oAuth2TwoLegged = new ForgeSDK.AuthClientTwoLegged(FORGE_CLIENT_ID, FORGE_CLIENT_SECRET, SCOPES);
const appPackageApi = new ForgeSDK.AppPackagesApi();
const getToken = () => {
return oAuth2TwoLegged.authenticate();
};
const getUploadURL = async (id) => {
const app = await appPackageApi.getAppPackage(id, oAuth2TwoLegged, oAuth2TwoLegged.getCredentials());
return app.body.Resource;
};
const patchPackage = (id, url) => {
const appPack = {
Resource: url,
RequiredEngineVersion: APP_PACKAGE_REQUIRED_ENGINE
};
return appPackageApi.patchAppPackage(id, appPack, oAuth2TwoLegged, oAuth2TwoLegged.getCredentials());
};
(async () => {
try {
const token = await getToken();
const url = await getUploadURL(APP_PACKAGE_ID);
const patchPackRes = await patchPackage(APP_PACKAGE_ID, url);
if (patchPackRes.statusCode == 201)
console.log('Patch package succeeded!');
else
console.log('Patch package failed!' + patchPackRes.statusCode);
} catch (ex) {
console.log('Exception :(');
console.log(ex);
}
})();