Autodesk Forge 设计自动化 - Inventor - failedInstructions (FailedMissingOutput)

Posted

技术标签:

【中文标题】Autodesk Forge 设计自动化 - Inventor - failedInstructions (FailedMissingOutput)【英文标题】:Autodesk Forge Design Automation - Inventor - failedInstructions (FailedMissingOutput) 【发布时间】:2020-04-25 04:23:33 【问题描述】:

我正在尝试使用 WorkItems API 将零件的关键参数提取到文本文件中。工作项因 FailedMissingOutput [KeyParameters.txt] 而失败,这是我的插件在工作文件夹中创建的文件。本地调试文件创建成功。

日志:

插件代码非常简单:

 public void RunWithArguments(Document doc, NameValueMap map)
    
        LogTrace("Processing " + doc.FullFileName);
        LogInputData(doc, map);

        try
        

            var DocDir = System.IO.Path.GetDirectoryName(doc.FullFileName);
            var ParametersOutputFileName = System.IO.Path.Combine(DocDir, "KeyParameters.txt");

            if (doc.DocumentType == DocumentTypeEnum.kPartDocumentObject)
            
                using (new HeartBeat())
                
                    // TODO: handle the Inventor part here

                    PartDocument PartDoc = (PartDocument)doc;
                    ExtractKeyParams(PartDoc.ComponentDefinition.Parameters, ParametersOutputFileName);

                
            
            else if (doc.DocumentType == DocumentTypeEnum.kAssemblyDocumentObject) // Assembly.
            
                using (new HeartBeat())
                
                    // TODO: handle the Inventor assembly here

                    AssemblyDocument AssyDoc = (AssemblyDocument)doc;
                    ExtractKeyParams(AssyDoc.ComponentDefinition.Parameters, ParametersOutputFileName);
                
            
        
        catch (Exception e)
        
            LogError("Processing failed. " + e.ToString());
        
    

    public void ExtractKeyParams(Parameters Params, string OutputFileName)

    
        List<string> ParamList = new List<string>();
        foreach (Parameter Param in Params)
        
            if (Param.IsKey)
            
                ParamList.Add(Param.Name);
            
        

        string[] OutputParams = ParamList.ToArray();
        System.IO.File.AppendAllLines(OutputFileName, OutputParams);

    

活动参数...

    private static Dictionary<string, Parameter> GetActivityParams()
    
        return new Dictionary<string, Parameter>
                
                    
                        Constants.Parameters.InventorDoc,
                        new Parameter
                        
                            Verb = Verb.Get,
                            Description = "File to process"
                        
                    ,
                    
                        "OutputParams",
                        new Parameter
                        
                            Verb = Verb.Put,
                            LocalName = "KeyParameters.txt",
                            Description = "Key Parameters Output",
                            Ondemand = false,
                            Required = false
                        
                    
                ;
    

.....和工作项参数(删除了令牌和 ids),签名资源是一个伪造的存储桶资源,生成将在 60 分钟内到期,所以这不应该是问题,

private static Dictionary<string, IArgument> GetWorkItemArgs()
    

        Dictionary<string, string> Header = new Dictionary<string, string>();
        Header.Add("Authorization", "Bearer <ACCESS_TOKEN>");

        Dictionary<string, string> Header2 = new Dictionary<string, string>();
        Header2.Add("Authorization", "Bearer <ACCESS_TOKEN>");
         Header2.Add("Content-type", "application/octet-stream");

        return new Dictionary<string, IArgument>
                
                    
                        Constants.Parameters.InventorDoc,
                        new XrefTreeArgument
                        
                            Url = "https://developer.api.autodesk.com/oss/v2/buckets/<BUCKET_KEY>/objects/box.ipt",
                            Headers = Header
                        
                    ,
                    
                        "OutputParams",
                        new XrefTreeArgument
                        
                            Verb = Verb.Put,
                            Url = "https://developer.api.autodesk.com/oss/v2/signedresources/<SIGNED_RESOURCE_ID>?region=US",
                            Headers = Header2
                        
                    
                ;
    

我无法弄清楚为什么我的插件没有生成 KeyParameters.txt 文件,但查看日志似乎是这样,也许问题是将其上传到签名资源,我的令牌具有所有需要的范围.

【问题讨论】:

你能确定OSSbucket中的box.ipt文件是那个有用户参数的吗?您可以使用oss-manager.autodesk.io 之类的实用程序下载文件 - 您也可以使用它为文件生成签名 URL 【参考方案1】:

KeyParameters.txt 文件未生成,因为您的 Activity 调用此函数 Run(Document doc)。可以在你的日志中看到它,检查这一行:

InventorCoreConsole.exe Information: 0 : Run called with box.ipt

现在只需尝试将您的代码移动到 Run(Document doc) 函数。

RunWithArguments(Document doc, NameValueMap map) 函数会在您的 Activity 的命令行中有任何参数时被调用。 https://forge.autodesk.com/en/docs/design-automation/v3/developers_guide/field-guide/#command-lines

【讨论】:

啊,真不敢相信我错过了,谢谢! 好吧,我也没有发现 - 如果有帮助:)【参考方案2】:

从错误消息看来,您的插件要么没有生成“KeyParameters.txt”文件,要么在错误的位置生成它。 您的代码是否有可能永远不会输入任何 if 语句,或者它最终在 catch 语句中而不创建 txt 文件? 您可以使用 reportUrl 下载报告,其中可能有更多信息。您还可以在此处添加更多登录信息,以帮助您了解正在发生的事情。

【讨论】:

以上是关于Autodesk Forge 设计自动化 - Inventor - failedInstructions (FailedMissingOutput)的主要内容,如果未能解决你的问题,请参考以下文章

Autodesk Forge 设计自动化/模型衍生 API - 查看器缓存 svf 文件

Autodesk Forge 数据管理参考 API 未列出 Revit 参考

Autodesk Forge 自动化

Autodesk forge 突出显示子对象

Autodesk forge 查看其他 3d 视图和选项

Autodesk Forge BIM 360 API - 激活服务类型