0

我正在使用 Forge 数据管理 API 访问我的 A360 文件,并旨在将它们转换为 SVF 格式,以便我可以在查看器中查看它们。到目前为止,我已经能够使用 ForgeDataManagement.ItemsApi 到达所需的项目,但我不知道如何处理该项目以将其上传到我的应用程序中的存储桶。

从文档看来 uploadObject 是要走的路(https://github.com/Autodesk-Forge/forge.oss-js/blob/master/docs/ObjectsApi.md#uploadObject),但我不知道究竟如何使这个功能工作。

var dmClient = ForgeDataManagement.ApiClient.instance;
var dmOAuth = dmClient.authentications ['oauth2_access_code'];
dmOAuth.accessToken = tokenSession.getTokenInternal();
var itemsApi = new ForgeDataManagement.ItemsApi();

fileLocation = decodeURIComponent(fileLocation);
var params = fileLocation.split('/');
var projectId = params[params.length - 3];
var resourceId = params[params.length - 1];

itemsApi.getItemVersions(projectId, resourceId)
 .then (function(itemVersions) {
   if (itemVersions == null || itemVersions.data.length == 0) return;

   // Use the latest version of the item (file).
   var item = itemVersions.data[0];

   var contentLength = item.attributes.storageSize;                  
   var body = new ForgeOSS.InputStream();
   // var body = item; // Using the item directly does not seem to work.
   // var stream = fs.createReadStream(...) // Should I create a stream object lik suggested in the documention?

   objectsAPI.uploadObject(ossBucketKey, ossObjectName, contentLength, body, {}, function(err, data, response) {
     if (err) {
       console.error(err);
     } else {
       console.log('API called successfully. Returned data: ' + data);

       //To be continued...
     }

我希望有人可以帮助我!

我目前的数据:

ossObjectName = "https://developer.api.autodesk.com/data/v1/projects/"myProject"/items/urn:"myFile".dwfx";
ossBucketKey = "some random string based on my username and id";

问候, torjuss

4

2 回答 2

0

在 Adam Nagy 的一些支持下,我们想出了如何让事情顺利进行。简而言之,我们必须使用 3 腿 OAuth 来完成所有操作,因为所有操作都涉及来自 A360 帐户的文档。这包括访问和显示文件结构、将文档翻译为 SVF、启动查看器并将文档加载到查看器中。

此外,我们在尝试翻译文档时定位到了错误的 ID。这篇文章展示了现在可以轻松完成它,感谢亚当提供的信息!

于 2016-12-29T20:30:42.097 回答
0

使用 DataManagement API 时,您可以使用

  • 2 个有腿的 oAuth (client_credentials) 并访问 OSS 的存储桶和对象,
  • 或 3 条腿 (authorization_code) 并访问用户的集线器、项目、文件夹、项目和修订

使用 3 legged 时,您确实在 A360 或 BIM360 上访问了某人的内容,并且这些文件由系统自动翻译,因此您无需再次翻译它们,而不是在 2 legged 应用程序桶上传输它们。您唯一需要做的就是获取 Item 的清单或其修订版,并使用 URN 在查看器中查看它。

在此处查看示例:https ://developer.autodesk.com/en/docs/data/v2/reference/http/projects-project_id-versions-version_id-GET/

您会看到类似示例:成功检索特定版本 (200)

curl -X GET -H "Authorization: Bearer kEnG562yz5bhE9igXf2YTcZ2bu0z" "https://developer.api.autodesk.com/data/v1/projects/a.45637/items/urn%3Aadsk.wipprod%3Adm.lineage%3AhC6k4hndRWaeIVhIjvHu8w"
{
  "data": {
    "relationships": {
      "derivatives": {
        "meta": {
          "link": {
            "href": "/modelderivative/v2/designdata/dXJuOmFkc2sud2lwcWE6ZnMuZmlsZTp2Zi50X3hodWwwYVFkbWhhN2FBaVBuXzlnP3ZlcnNpb249MQ/manifest"
          }
        },

现在,为了回答有关上传的其他问题,我在这里找到了一个示例: https ://github.com/Autodesk-Forge/forge.commandline-nodejs/blob/master/forge-cb.js#L295 。我这里复制了相关代码给大家看看如何使用:

fs.stat (file, function (err, stats) {
    var size =stats.size ;
    var readStream =fs.createReadStream (file) ;
    ossObjects.uploadObject (bucketKey, fileKey, size, readStream, {}, function (error, data, response) {
        ...
    }) ;
}) ;

请记住,ossObjects 是 2 条腿的,而 Items 是 3 条腿的。

于 2016-12-15T08:04:13.333 回答