Is it possible to set a version free variable via API without showing in the file history.

Discuss SolidWorks PDM
User avatar
bnemec
Posts: 1960
Joined: Tue Mar 09, 2021 9:22 am
Answers: 10
Location: Wisconsin USA
x 2568
x 1420

Is it possible to set a version free variable via API without showing in the file history.

Unread post by bnemec »

I would like to set a version free variable on files without creating an entry on the file history. This will be set on several two or three thousand files a day and will make using file history difficult as there will be hundreds of irrelevant rows.

I tried both settings on the version free variable, all versions or latest only. I don't really know the difference between them, I'm guessing the "all versions" option will only have one record for the file in SQL where latest only will store the version in the the table with the version number where value was last changed. I would prefer the simplest method, no historical data needed at all for this variable.

I'm using the BatchUpdate2 utility with flags 1 and 2 to change all configs and update if not on any card. I've searched the help for anything related to file history and if it's there I'm missing it.

Thank you.
image.png
User avatar
mp3-250
Posts: 660
Joined: Tue Sep 28, 2021 4:09 am
Answers: 20
Location: Japan
x 742
x 361

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by mp3-250 »

I do not think it is possible.
We get a lot of history entries from action performed by the pdm system when a user open a file, probably because we transitioned the variable from custom properties to db only and from history to history free.(which was a mess of a choice imho.)

Not logging those actions would be a compliance problem imho.
User avatar
bnemec
Posts: 1960
Joined: Tue Mar 09, 2021 9:22 am
Answers: 10
Location: Wisconsin USA
x 2568
x 1420

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by bnemec »

mp3-250 wrote: Thu Oct 03, 2024 4:47 pm I do not think it is possible.
We get a lot of history entries from action performed by the pdm system when a user open a file, probably because we transitioned the variable from custom properties to db only and from history to history free.(which was a mess of a choice imho.)

Not logging those actions would be a compliance problem imho.
Thank you for the info. The variable I just created and it has been version free since first created. I can see that logging when user opens/caches a file is important information for some data. In our case this is a date field that is updated when things happen in the ERP system. I've been doing testing and looking at the SQL tables, namely [dbo].[VariableValue] and [dbo].[HistoryVerFreeVarChanged], don't know where else to look. I'm pretty sure the latter is the table that populates these rows in the file history view. In theory using a SQL update statement on the VariableValue table for the specific file, variableID and revisionNo 0 would do the trick. But I'm not interested in doing edits directly to the vault's SQL tables.

Current behavior is a show stopper for our project, will need to find a new way.
User avatar
bnemec
Posts: 1960
Joined: Tue Mar 09, 2021 9:22 am
Answers: 10
Location: Wisconsin USA
x 2568
x 1420

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by bnemec »

I'm wondering which would be worse.
Using a SQL command "DELETE FROM [Vault].[dbo].[HistoryVerFreeVarChanged] WHERE UserId = 2 and Name = LastActiveDate" after running Batch variable update.
Or using UPDATE on the VariableValues table.
User avatar
mp3-250
Posts: 660
Joined: Tue Sep 28, 2021 4:09 am
Answers: 20
Location: Japan
x 742
x 361

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by mp3-250 »

bnemec wrote: Fri Oct 04, 2024 3:58 pm I'm wondering which would be worse.
Using a SQL command "DELETE FROM [Vault].[dbo].[HistoryVerFreeVarChanged] WHERE UserId = 2 and Name = LastActiveDate" after running Batch variable update.
Or using UPDATE on the VariableValues table.
just an idea I do not know if it is silly or it does not work in your peculiar case, but there is the possibility for a field in the PDM datacard to be updated at a fixed interval from an external db with a temporary table and a sql query.

I tested only once with a drop down menu and it indeed fills the field dynamically. just to avoid messing with pdm db directly.
User avatar
jcapriotti
Posts: 1912
Joined: Wed Mar 10, 2021 6:39 pm
Answers: 32
Location: The south
x 1246
x 2034

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by jcapriotti »

Is this updated every few minutes actually changing a value or is the value the same most of the time but the program updates it anyway?

If this is true, can the import program be made smarter and only import when the value changes?
Jason
User avatar
bnemec
Posts: 1960
Joined: Tue Mar 09, 2021 9:22 am
Answers: 10
Location: Wisconsin USA
x 2568
x 1420

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by bnemec »

jcapriotti wrote: Sun Oct 06, 2024 9:51 pm Is this updated every few minutes actually changing a value or is the value the same most of the time but the program updates it anyway?

If this is true, can the import program be made smarter and only import when the value changes?
Well, the plan was to run once a day. The query to eternal DB and C# code filters the list down to only the files that should be updated. There will be many files that are updated daily, others once a year or maybe less. We could drop down to run maybe once a week, but there will still be files with 50 extra rows in the file history every year.
User avatar
bnemec
Posts: 1960
Joined: Tue Mar 09, 2021 9:22 am
Answers: 10
Location: Wisconsin USA
x 2568
x 1420

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by bnemec »

mp3-250 wrote: Sun Oct 06, 2024 6:12 pm just an idea I do not know if it is silly or it does not work in your peculiar case, but there is the possibility for a field in the PDM datacard to be updated at a fixed interval from an external db with a temporary table and a sql query.

I tested only once with a drop down menu and it indeed fills the field dynamically. just to avoid messing with pdm db directly.
I'm interested. I had not heard of this so I did some searching. I found this in PDM Help:
https://help.solidworks.com/2019/Englis ... AuMA..#Pg0

This sounds similar to what you're saying with the temporary table bit. I was getting hopeful up until the part about the updates wait in that temp table until the file(s) go through an import transition action. I'm already setting this variable to current date as an action on the common workflow transitions. The purpose of the updating through API was to get the files that may not be touched for a couple of years.

Nevertheless this is a good suggestion and something to keep in mind. Would work well for updating a non-version free variable such as "Description" from the ERP side (for cases where the ERP side is the controlling single source of truth.)
When the rule runs, the database server searches the folder for XML files containing valid values and commits them to the database in the ImportBatches table. Imported variable values are stored in the ImportDocumentVariables table. Imported values are not updated in the file stored in the vault until the file goes through an import transition action.
User avatar
AlexB
Posts: 508
Joined: Thu Mar 18, 2021 1:38 pm
Answers: 29
x 275
x 463

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by AlexB »

bnemec wrote: Mon Oct 07, 2024 9:40 am I'm interested. I had not heard of this so I did some searching. I found this in PDM Help:
https://help.solidworks.com/2019/Englis ... AuMA..#Pg0
I've always been curious about this myself. We don't have any applications that would use this (yet) but nevertheless I feel like it's a good idea to see how to use it in my test vault.
User avatar
jcapriotti
Posts: 1912
Joined: Wed Mar 10, 2021 6:39 pm
Answers: 32
Location: The south
x 1246
x 2034

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by jcapriotti »

bnemec wrote: Mon Oct 07, 2024 8:35 am Well, the plan was to run once a day. The query to eternal DB and C# code filters the list down to only the files that should be updated. There will be many files that are updated daily, others once a year or maybe less. We could drop down to run maybe once a week, but there will still be files with 50 extra rows in the file history every year.
So this date for these files actually change daily?
Jason
User avatar
bnemec
Posts: 1960
Joined: Tue Mar 09, 2021 9:22 am
Answers: 10
Location: Wisconsin USA
x 2568
x 1420

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by bnemec »

jcapriotti wrote: Tue Oct 08, 2024 10:32 am So this date for these files actually change daily?
Some do, it depends on orders. The intent is to filter out, mostly automatically, CAD files that are not in use. Explaining the why would take me a while, I'm not good at summarizing. Several of us came up with a plan to try. Step one is keep a "last active date" on each model file. The obvious and simple options such as state change are implemented but we need to keep all the files that are used in any active product but seldom touched in PDM, which is where the question in this thread comes in. The plan is to take the list of finished good part numbers shipped each day from the ERP side to get the list of CAD files that were involved in supporting those and update the "last active date". Which all seems to work as desired except for this pesky side effect of filling the file history view with irrelevant rows.

The other portion will be a scheduled task that gets all the files with last active date older than x and does some more filtering then either sends them to an obsolete type state or sends notification to selected user when human decision is needed.
User avatar
jcapriotti
Posts: 1912
Joined: Wed Mar 10, 2021 6:39 pm
Answers: 32
Location: The south
x 1246
x 2034

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by jcapriotti »

@bnemec I get it now. We have some of the same issues if I understand correctly. We "inactivate" parts and products that are no longer current, but we still need to make parts for repair and replacement. So they are "Active" in our factory. Eventually orders for these parts fall off after products in the field get replaced and upgraded. So I think there are order dates in our ERP and other systems which never really make it back to engineering so we can finally put the product to bed and archive it.

Not sure how exactly I would tackle this. Probably a custom SQL DB that receives the ERP dates. If you didn't require the data card variable be updated, I would assign a command button that opens the date report for that part. Maybe include other ERP data that is useful to engineering.....like cost.

If it must be on the data card, you could try editing the "VariableValue" table directly. I've been "told' by certain "someones" that its fairly safe (no triggers or stored procedures). Pretty sure the company that did our initial PDF import added the meta data directly to this table. I manually correct it all the time and had thought many times about automating the more common tasks. Just need the DocumentID and VariableID.
Jason
User avatar
bnemec
Posts: 1960
Joined: Tue Mar 09, 2021 9:22 am
Answers: 10
Location: Wisconsin USA
x 2568
x 1420

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by bnemec »

In case anyone cares, what I settled on is calling this function. I use the id of logged in user (a user account only used for automation) in the sql statement. The return value is compared against the number of files expected to have been edited.

Code: Select all

    private static int ClearLastActiveDateHistory()
    {
      int rowsDeleted = 0;
      using (SqlConnection findSEfilesConn = new SqlConnection(mssqlConnString))
      {
        findSEfilesConn.Open();
        using (SqlCommand cmd = new SqlCommand("", findSEfilesConn))
        {
          IEdmUserMgr10 userMgr = vault.CreateUtility(EdmUtility.EdmUtil_UserMgr);
          cmd.CommandText = "delete FROM[Vault].[dbo].[HistoryVerFreeVarChanged] " +
            "where Name = '" + LAST_ACT_VAR_NAME + "' and  userID = " + userMgr.GetLoggedInUser().ID + "; ";
          SqlDataReader reader = cmd.ExecuteReader();
          if (reader != null)
          {
            rowsDeleted = reader.RecordsAffected;
          }
        }
      }
      return rowsDeleted;
    }
  }
hcgord
Posts: 4
Joined: Fri Dec 13, 2024 2:20 pm
Answers: 0

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by hcgord »

Interestingly I'm working a project and I also encountered the unwanted history entries when modifying version free variables. I was wondering if you have noticed any unwanted effects of deleting values from [dbo].[HistoryVerFreeVarChanged]?
User avatar
bnemec
Posts: 1960
Joined: Tue Mar 09, 2021 9:22 am
Answers: 10
Location: Wisconsin USA
x 2568
x 1420

Re: Is it possible to set a version free variable via API without showing in the file history.

Unread post by bnemec »

No side effects yet. Been running since early December. I like making use of the result value of records modified to identify if something unexpected happened, as I knew how many there should in there unless that user edited that value outside of that API.
I have noticed some files that have different dates for different configs. The VariableValue for that variable and config name is blank (null) didn't get updated by my API. I have not yet looked into what's causing that. Of course it presents in confusing ways as all the various places to see the variable (contains, where used, data card, SW PDM Addin, etc) pull from different config. Configurations certainly add a layer of complexity to everything I've done in PDM.

In this example the file was created 2024-09-19 then later the API updated the value to 2024-05-28 on the configs it could find but missed the blank config. :roll:
image.png

I just went and looked at code and remembered that I used batch updater, I set the update all configs flag so who knows...

Code: Select all

      //Create a batch update utility
      IEdmBatchUpdate2 batchUpdater2 = default(IEdmBatchUpdate2);
      batchUpdater2 = (IEdmBatchUpdate2)vault.CreateUtility(EdmUtility.EdmUtil_BatchUpdate);

      //Get the IDs of the file and folder card variables to update
      int lastActiveDateID = 0;
      IEdmVariableMgr5 VariableMgr = default(IEdmVariableMgr5);
      VariableMgr = (IEdmVariableMgr5)vault;
      lastActiveDateID = VariableMgr.GetVariable(LAST_ACT_VAR_NAME).ID;
      int batchFlags = (int)EdmBatchFlags.EdmBatch_AllConfigs + (int)EdmBatchFlags.EdmBatch_UpdateVarIfNotPartOfCard;
Post Reply