# Upgrade

## Overview

The following procedures apply to the WorkflowGen 10.0.3 upgrade pack, available at <https://github.com/advantys/workflowgen-releases/releases>.

## Package contents

The upgrade pack is distributed as a compressed file containing the following folders:

* `Inetpub`: WorkflowGen web application files&#x20;
* `Program Files`: WorkflowGen Windows Services files
* `Databases`: WorkflowGen database update and creation files

## IIS server

Stop the IIS server (or at least your WorkflowGen web applications) if other websites are using the same IIS server.

## WorkflowGen Windows Services

Stop the WorkflowGen Directory Sync and Engine services in the Windows Services Management Console.

## Backup

### Application and data files

Back up the following folders:

* `DRIVE:\Inetpub\wwwroot\wfgen`
* `DRIVE:\Program Files\Advantys\WorkflowGen`

If the file storage path isn't the standard `DRIVE:\Inetpub\wwwroot\wfgen\App_Data` path, then you have to back up the corresponding folder.

### Database

Perform a standard database backup using your DBMS tools.

## Update WorkflowGen web application files

### Delete deprecated Node.js application files and folders

Verify if the following deprecated files and folders used by Node.js-based applications still exist in your `\wfgen` folder, and delete them if they do.

1. Delete the following files and folders from the `\wfgen\graphql` folder:
   * `\controllers`
   * `\models`
   * `\node_modules`
   * `\services`
   * `\utils`
   * `config.js`
   * `config.production.js`
   * `server.js` <br>
2. Delete the following files and folders from the `\wfgen\hooks` folder:
   * `\controllers`
   * `\models`
   * `\node_modules`
   * `\services`
   * `\test`
   * `\utils`
   * `config.js`
   * `config.production.js`
   * `server.js`
   * `upload.js` <br>
3. Delete the following files and folders from the `\wfgen\auth` folder:
   * `\controllers`
   * `\models`
   * `\node_modules`
   * `\static`
   * `\utils`
   * `config.js`
   * `config.production.js`
   * `server.js` <br>
4. Delete the following files and folders from the `\wfgen\scim` folder:
   * `\controllers`
   * `\models`
   * `\node_modules`
   * `\services`
   * `\utils`
   * `config.js`
   * `config.production.js`
   * `server.js`

### Delete deprecated assembly files

Delete the following deprecated assembly `.dll` files from the `\wfgen\bin`, `\wfgen\ws\bin`, and `\Program Files\Advantys\WorkflowGen\services\bin` folders:

* `Advantys.Directories`
* `Advantys.Directories.Web.UI.Administration`
* `Advantys.Web.UI.Charting`
* `Advantys.Workflow.Applications.ExecSql`
* `Advantys.Workflow.Applications.GetUsersFromDir`
* `Advantys.Workflow.Applications.MergeForm`
* `Advantys.Workflow.Applications.RestApiClient`
* `Advantys.Workflow.Applications.SendMessage`
* `Advantys.Workflow.Applications.XmlToDatabase`
* `Advantys.Workflow.Applications.XmlTrans`
* `Advantys.Workflow.Reports`
* `Advantys.Workflow.Web.UI.Reports`

### Copy the upgrade pack content

Copy and overwrite the upgrade content from `Update\Inetpub\wwwroot\wfgen` to your WorkflowGen web application folder. By default, the suggested physical path is `DRIVE:\Inetpub\wwwroot\wfgen`.

{% hint style="warning" %}

* Domain users and the Windows accounts used to run the WorkflowGen IIS application pool and Engine service must have read and write permissions for the `\wfgen\App_Data` folder.
* Do **NOT** copy and overwrite your existing `DRIVE:\Inetpub\wwwroot\wfgen\web.config` file if you want to keep your current WorkflowGen configuration settings and database connection information.
* It’s possible that the following default CSS files have been updated in this release and could overwrite any changes you had made in your existing installation:
  * `\wfgen\App_Themes\Default\portal\css\Default.css`
  * `\wfgen\App_Themes\Default\admin\css\Default.css`&#x20;
* If you've made changes to any of the default files in the following folders (e.g. `*.aspx`, `*.css`, `*.resx` files), make a backup of the existing files prior to the upgrade and manually re-apply these changes to the corresponding version 9.x.x files:
  * `\wfgen`
  * `\wfgen\App_Themes`
  * `\wfgen\App_Data\Templates\Emails`
  * `\wfgen\App_Data\Templates\Forms`
  * `\wfgen\App_Data\Templates\Processes`
    {% endhint %}

## Update WorkflowGen Windows Services files

### Delete deprecated DLL file

Delete the deprecated `DRIVE:\Program Files\Advantys\WorkflowGen\Services\bin\EAGetMail40.dll` file.

### Overwrite the WorkflowGen Windows Services folder

Overwrite the contents of your WorkflowGen Windows Services folder with the contents of `Update\Program Files\Advantys\WorkflowGen`. By default, the suggested physical path is `DRIVE:\Program Files\Advantys\WorkflowGen`.

{% hint style="danger" %}
Do **NOT** copy and overwrite your existing `DRIVE:\Program Files\Advantys\WorkflowGen\Services\bin\*.config` files.
{% endhint %}

## Update Node.js program files

First, overwrite the contents of your Node.js program folder with the contents of `Update\Program Files\Nodejs`.  By default, the suggested physical path is `DRIVE:\Program Files\Nodejs`.

Then, copy `node.exe.config` and `trace.config` (located in `Update\Program Files\Nodejs`) to `DRIVE:\Program Files\Nodejs`.&#x20;

{% hint style="warning" %}
If there's already a `node.exe.config` file in the `DRIVE:\Program Files\Nodejs` folder, **do not overwrite it**. Instead, add the following to the existing file's `<configuration>` node:

```html
<runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
        <dependentAssembly>
            <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-13.0.0.0" newVersion="13.0.0.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Runtime.CompilerServices.Unsafe" publicKeyToken="b03f5f7f11d50a3a" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-6.0.3.0" newVersion="6.0.3.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Text.Json" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-8.0.0.5" newVersion="8.0.0.5" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Buffers" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-4.0.5.0" newVersion="4.0.5.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Memory" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-4.0.5.0" newVersion="4.0.5.0" />
        </dependentAssembly>
    </assemblyBinding>
</runtime>
```

{% endhint %}

## Update configuration files

This section contains configuration parameter changes you need to apply, based on the version of WorkflowGen from which you're upgrading.

{% hint style="warning" %}
This section has been divided to provide a quicker reference for clients upgrading from **version 8.0.0 and later**. If you're upgrading from **version 7.22.15 or earlier**, see the [Legacy Upgrade](https://docs.workflowgen.com/upgrade/10.0.3/workflowgen-upgrade/legacy-upgrade) section and perform the required modifications to the configuration files based on the version from which you're upgrading, then return to this section and continue with the rest of the required modifications.
{% endhint %}

#### 📌 Examples

* When upgrading to version 10.0.3 from version 9.2.4, apply the changes in the **When upgrading from version 9.2.5 and earlier**, **When upgrading from version 9.2.9 and earlier**, and **When upgrading from all 9.x.x versions and earlier** sections.
* When upgrading to version 10.0.3 from version 10.0.2, there are no changes to make to the configuration files.

#### When upgrading from version 8.0.0 and earlier

1. Add the following new parameters to `<appSettings>`:

   <pre class="language-html"><code class="lang-html"><strong>&#x3C;add key="RemoteApprovalAuthClientId" value="" />
   </strong>&#x3C;add key="RemoteApprovalAuthClientSecret" value="" />
   &#x3C;add key="RemoteApprovalAuthScope" value="" />
   &#x3C;add key="RemoteApprovalAuthAccessTokenUri" value="" />
   </code></pre>

2. Remove the following deprecated parameter from `<appSettings>`:

   ```markup
   EngineTraceMode
   ```

#### When upgrading from version 8.0.1 and earlier

Add the following new parameters to `<appSettings>`:

```html
<!-- AdobeSign -->
<add key="AdobeSignClientId" value="" />
<add key="AdobeSignClientSecret" value="" />
<add key="AdobeSignHostServer" value="" />
<add key="AdobeSignRefreshToken" value="" />
<add key="AdobeSignSendLogLevel" value="0" />
<add key="AdobeSignCheckLogLevel" value="0" />
```

#### When upgrading from version 8.0.2 and earlier

Add the following new parameters to `<appSettings>`:

```html
<add key="EngineNotificationNotifyDelegator" value="Y" />
<add key="EnginePushNotificationSendExpoApiUrl" value="https://exp.host/--/api/v2/push/send" />

<!-- Docaposte -->
<add key="DocaposteUsername" value="" />
<add key="DocapostePassword" value="" />
<add key="DocaposteHostServer" value="" />
<add key="DocaposteOfferCode" value="" />
<add key="DocaposteOrganizationalUnitCode" value="" />
<add key="DocaposteSendLogLevel" value="0" />
<add key="DocaposteCheckLogLevel" value="0" />
```

#### When upgrading from version 8.0.7 and earlier

1. Add the following new parameter to `<appSettings>` :

   ```xml
   <add key="EngineServiceMaxPausedSynchroActions" value="25" />
   ```

2. Update the value of the `EngineServiceTimeoutSystemActionFrequency` parameter to `120000` as follows:

   ```xml
   <add key="EngineServiceTimeoutSystemActionFrequency" value="120000" />
   ```

#### When upgrading from version 8.0.10 and earlier

Add the following new parameter to `<appSettings>` :

```xml
<add key="PortalReportAdvancedViewPaging" value="N" />
```

#### When upgrading from version 8.1.0 Beta and earlier

1. Update the value of the following parameter in `<appSettings>`:

   <pre class="language-xml"><code class="lang-xml"><strong>&#x3C;add key="PortalListPageSize" value="25" />
   </strong></code></pre>

2. Remove the following parameters from `<appSettings>` from version **8.1.0 Beta** only:

   ```xml
   <add key="PortalReportAdvancedViewPageSize" value="25" />
   <add key="PortalReportAdvancedViewPageSizeOptions" value="10,25,50,100,250" />
   ```

#### When upgrading from version 8.1.2 and earlier

Add the following new parameters to `<appSettings>` :

```xml
<add key="GraphqlApiKeyEnabled" value="N" />
<add key="GraphqlApiKey" value="" />
```

#### When upgrading from version 8.1.3 and earlier

1. Add the following new parameters to `<appSettings>`:

   ```html
   <add key="PortalDisplayAssignedTeamAction" value="N" />
   <add key="HooksAllowImpersonateUser" value="N" />
   <add key="HooksApiKeyEnabled" value="N" />
   <add key="HooksApiKey" value="" />
   ```

2. Update the `bindingRedirect` node in all of the affected configuration files (listed below) from `<bindingRedirect oldVersion="0.0.0.0-12.0.0.0" newVersion="12.0.0.0" />` to `<bindingRedirect oldVersion="0.0.0.0-13.0.0.0" newVersion="13.0.0.0" />`:
   * `\wfgen\web.config`
   * `\wfgen\ws\web.config`
   * `\Program Files\Advantys\WorkflowGen\Services\bin\WfgWorkflowEngineService.exe.config`
   * `\Program Files\nodejs\node.exe.config`&#x20;

#### When upgrading from version 8.2.4 and earlier

1. Add the following new parameter to `<appSettings>`:

   ```html
   <add key="ApplicationDefaultFullWidth" value="N" />
   ```

2. Update the value of the following parameter in `<appSettings>`:

   ```html
   <add key="PortalCommentsPopUpHeight" value="600" />
   ```

3. Remove the following deprecated parameters from `<appSettings>`:

   ```html
   ChartServiceAvoidColorCollision
   ChartServiceMaxSliceInPie
   ReportsChartServiceUrl
   ReportsChartTemplatePath
   ReportsChartTemplateExtension
   ```

#### When upgrading from version 8.2.4 and earlier OR from version 9.0.0 Beta (v9 Beta 1)

Add the following new parameters to `<appSettings>`:

```html
<!-- Auth: Gardian -->
<add key="ApplicationSecurityAuthAcrValues" value="" />

<add key="AdobeSignRefreshUrl" value="/oauth/v2/refresh" />

<!-- Yousign -->
<add key="YousignApiKey" value="" />
<add key="YousignHostServer" value="" />
<add key="YousignSendLogLevel" value="0" />
<add key="YousignCheckLogLevel" value="0" />
```

#### When upgrading from version 9.0.1 Beta (v9 Beta 2) and earlier

Add the following new parameters to `<appSettings>`:

```html
<add key="PortalDisplayRequestListWithActionsFollowUp" value="N" />

<!-- OpenAi -->
<add key="OpenAiApiKey" value="" />
<add key="OpenAiTranscriptionLogLevel" value="0" />
```

#### When upgrading from version 9.0.2 Beta (v9 Beta 3) and earlier

Add the following new parameter to `<appSettings>`:

```xml
<add key="OpenAiChatLogLevel" value="0" />
```

#### When upgrading from version 9.0.7 and earlier

1. Rename the following parameters in `<appSettings>`:

   <pre class="language-html"><code class="lang-html"><strong>&#x3C;!-- OpenAI -->
   </strong>OpenAiApiKey
   OpenAiTranscriptionLogLevel
   OpenAiChatLogLevel
   </code></pre>

   as

   ```html
   <!-- OpenAI -->
   OpenAIApiKey
   OpenAITranscriptionLogLevel
   OpenAIChatLogLevel
   ```
2. Add the following new parameter to `<appSettings>`:

   <pre class="language-html"><code class="lang-html"><strong>&#x3C;!-- OpenAI -->
   </strong>&#x3C;add key="OpenAIChatApiUrl" value="" />
   </code></pre>

#### When upgrading from version 9.1.0 and earlier

If you want to enable default HTTP error handling by WorkflowGen, replace the following parameter in `<appSettings>`:

```html
<customErrors mode="Off"/>
```

with the following:

```html
<customErrors mode="On" defaultRedirect="default_error_page.htm">
    <error statusCode="401" redirect="401.htm" />
    <error statusCode="404" redirect="404.htm" />
    <error statusCode="500" redirect="500.htm" />
</customErrors>
```

#### When upgrading from version 9.2.9 and earlier

1. Enable `ApplicationSecurityEnableWebAppsSecureMode` by setting this parameter to `Y`, as shown here:

   ```html
   <add key="ApplicationSecurityEnableWebAppsSecureMode" value="Y" />
   ```
2. Add the following new parameter and define a custom encryption key:

   ```html
   <add key="ApplicationSecurityEncryptionKey" value="CUSTOM_KEY" />
   ```

{% hint style="warning" %}

* Replace `CUSTOM_KEY` with at least **32 characters (256 bits)** for strong encryption. Use a combination of uppercase and lowercase letters, numbers, and special characters.
* Clients using custom Visual Studio webforms should be upgrading to and referencing the latest `WorkflowGen.My.dll` to support this update. If the webform uses its own `web.config`, the `ApplicationSecurityEnableWebAppsSecureMode` and `ApplicationSecurityEncryptionKey` keys should also be redefined there.
  {% endhint %}

#### When upgrading from version 9.2.11 and earlier

Add the following new parameters to `<appSettings>`:

```html
<add key="ApplicationDefaultFileUploadForbiddenExtensions" value="exe,msi,msm,bat,cmd,ps1,sh,bash,csh,php,asp,aspx,jsp" />
<add key="HooksRateLimitWindowMs" value="900000" />
<add key="HooksRateLimitMax" value="1000" />

<add key="XmlToJsonLogLevel" value="0" />

<!-- Dropbox Sign -->
<add key="DropboxSignApiKey" value="" />
<add key="DropboxSignHostServer" value="https://api.hellosign.com/v3" />
<add key="DropboxSignSendLogLevel" value="0" />
<add key="DropboxSignCheckLogLevel" value="0" />
```

Replace the following code in `<runtime>`:

```html
<runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
        <dependentAssembly>
            <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-13.0.0.0" newVersion="13.0.0.0" />
        </dependentAssembly>
    </assemblyBinding>
</runtime>
```

with the following:

```html
<runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
        <dependentAssembly>
            <assemblyIdentity name="Microsoft.IdentityModel.Logging" publicKeyToken="31bf3856ad364e35" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-8.2.0.0" newVersion="8.2.0.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="Microsoft.IdentityModel.Tokens" publicKeyToken="31bf3856ad364e35" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-8.2.0.0" newVersion="8.2.0.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-13.0.0.0" newVersion="13.0.0.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="Microsoft.IdentityModel.JsonWebTokens" publicKeyToken="31bf3856ad364e35" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-8.2.0.0" newVersion="8.2.0.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Runtime.CompilerServices.Unsafe" publicKeyToken="b03f5f7f11d50a3a" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-6.0.0.0" newVersion="6.0.0.0" />
        </dependentAssembly>
    </assemblyBinding>
</runtime>
```

#### When upgrading from all 9.x.x versions and earlier

**Step 1:** Add the following new parameters to `<appSettings>`:

<pre class="language-html"><code class="lang-html"><strong>&#x3C;add key="EngineServiceDataIndexingFrequency" value="10000" />
</strong>
&#x3C;!-- Chunks and Embeddings -->
&#x3C;add key="GenerateChunksBatchSize" value="200" />
&#x3C;add key="GenerateChunksSize" value="1000" />
&#x3C;add key="GenerateChunksOverlap" value="200" />
&#x3C;add key="GenerateChunksMaxCount" value="100" />
&#x3C;add key="GenerateChunksLanguageCode" value="0" />
&#x3C;add key="GenerateEmbeddingsApiProvider" value="openai" />
&#x3C;add key="GenerateEmbeddingsApiEndpoint" value="https://api.openai.com/v1/embeddings" />
&#x3C;add key="GenerateEmbeddingsApiKey" value="" />
&#x3C;add key="GenerateEmbeddingsApiModel" value="text-embedding-3-small" />
&#x3C;add key="GenerateEmbeddingsApiDimensions" value="384" />
&#x3C;add key="GenerateEmbeddingsApiCallDelay" value="100" />
&#x3C;add key="GenerateEmbeddingsApiMaxRetries" value="10" />
</code></pre>

⚠️ **Important:** The default language code for full-text search (`GenerateChunksLanguageCode` in the `web.config` file and `WFDATASET_CHUNK` database table index)  is set to `0` (Neutral). We recommend setting this to the appropriate language code that matches the primary language of your request data text and file values for better search results. For example, use `1033` for English or `1036` for French:

```xml
<add key="GenerateChunksLanguageCode" value="1033" />
```

You must also set the same language code in the database creation script (`Create_WFG_SQL_Indexes.sql`) or update script (`Update_WFG-V10-0-0.sql`) before running it:

```sql
CREATE FULLTEXT INDEX ON WFDATASET_CHUNK
(
    CHUNK LANGUAGE 1033 -- English
)
KEY INDEX PK_CHUNK
ON WFDATASET_CATALOG
```

To retrieve the full list of supported language codes, run the following SQL query in **SQL Server Management Studio (SSMS):**

```sql
select * from sys.fulltext_languages;
```

📌 Example of settings when using **OpenAI** embeddings API:

```xml
<add key="GenerateEmbeddingsApiProvider" value="openai" />
<add key="GenerateEmbeddingsApiEndpoint" value="https://api.openai.com/v1/embeddings" />
<add key="GenerateEmbeddingsApiKey" value="YOUR_OPENAI_API_KEY" />
<add key="GenerateEmbeddingsApiModel" value="text-embedding-3-small" />
```

📌 Example of settings when using **Azure OpenAI** embeddings API:

```xml
<add key="GenerateEmbeddingsApiProvider" value="azure-openai" />
<add key="GenerateEmbeddingsApiEndpoint" value="https://custom-domain.openai.azure.com" />
<add key="GenerateEmbeddingsApiKey" value="YOUR_AZURE_OPENAI_API_KEY" />
<add key="GenerateEmbeddingsApiModel" value="text-embedding-3-small" />
```

📌 Example of settings when using a local **LM Studio** server with a **custom text embedding** model:

```xml
<add key="GenerateEmbeddingsApiProvider" value="lm-studio" />
<add key="GenerateEmbeddingsApiEndpoint" value="http://localhost:1234/v1/embeddings" />
<add key="GenerateEmbeddingsApiKey" value="YOUR_LM_STUDIO_API_KEY" />
<add key="GenerateEmbeddingsApiModel" value="text-embedding-all-minilm-l6-v2-embedding" />
```

**Step 2:** Add the following new parameters to `<appSettings>`:

```html
<add key="GenerateEmbeddingsApiAuthMethod" value="bearer" />
<add key="GenerateEmbeddingsApiAuthHeader" value="Authorization" />
<add key="GenerateEmbeddingsApiRetriesDelay" value="5000" />
```

📌 Example of settings for **Azure OpenAI** that uses the `api-key` method and header:

```xml
<add key="GenerateEmbeddingsApiAuthMethod" value="api-key" />
<add key="GenerateEmbeddingsApiAuthHeader" value="api-key" />
```

📌 Example of settings for **OpenAI** and local **LM Studio** server that uses the `bearer` method and `Authorization` header:

```xml
<add key="GenerateEmbeddingsApiAuthMethod" value="bearer" />
<add key="GenerateEmbeddingsApiAuthHeader" value="Authorization" />
```

**Step 3:** In these configuration files:

* `\wfgen\web.config`
* `\Program Files\Advantys\WorkflowGen\Services\bin\WfgWorkflowEngineService.exe.config`
* `\Program Files\Advantys\WorkflowGen\Services\bin\WfgDirectoriesSyncService.exe.config`
* `\Program Files\nodejs\node.exe.config`&#x20;

add the following to the configuration node:

```html
<system.data>
    <DbProviderFactories>
        <add name="Npgsql Data Provider" invariant="Npgsql" description=".Net Data Provider for PostgreSQL" type="Npgsql.NpgsqlFactory, Npgsql, Culture=neutral, PublicKeyToken=5d8b90d52f46fda7"/>
    </DbProviderFactories>
</system.data> 
```

**Step 4:** In these configuration files:

* `\wfgen\web.config`
* `\wfgen\ws\web.config`
* `\Program Files\Advantys\WorkflowGen\Services\bin\WfgWorkflowEngineService.exe.config`
* `\Program Files\nodejs\node.exe.config`&#x20;

update the `<runtime>` node with the following (or add it if it's not defined):

```html
<runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
        <dependentAssembly>
            <assemblyIdentity name="Microsoft.IdentityModel.JsonWebTokens" publicKeyToken="31bf3856ad364e35" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-8.2.0.0" newVersion="8.2.0.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="Microsoft.IdentityModel.Logging" publicKeyToken="31bf3856ad364e35" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-8.2.0.0" newVersion="8.2.0.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="Microsoft.IdentityModel.Tokens" publicKeyToken="31bf3856ad364e35" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-8.2.0.0" newVersion="8.2.0.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-13.0.0.0" newVersion="13.0.0.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Runtime.CompilerServices.Unsafe" publicKeyToken="b03f5f7f11d50a3a" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-6.0.3.0" newVersion="6.0.3.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Text.Json" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-8.0.0.5" newVersion="8.0.0.5" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Buffers" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-4.0.5.0" newVersion="4.0.5.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Memory" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-4.0.5.0" newVersion="4.0.5.0" />
        </dependentAssembly>
    </assemblyBinding>
</runtime>

```

**Step 5:** In these configuration files:

* `\wfgen\wfapps\webforms\web.config`
* `\Program Files\Advantys\WorkflowGen\Services\bin\WfgDirectoriesSyncService.exe.config`

update the `<runtime>` node with the following (or add it if it's not defined):

```xml
<runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
        <dependentAssembly>
            <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-13.0.0.0" newVersion="13.0.0.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Runtime.CompilerServices.Unsafe" publicKeyToken="b03f5f7f11d50a3a" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-6.0.3.0" newVersion="6.0.3.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Text.Json" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-8.0.0.5" newVersion="8.0.0.5" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Buffers" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-4.0.5.0" newVersion="4.0.5.0" />
        </dependentAssembly>
        <dependentAssembly>
            <assemblyIdentity name="System.Memory" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
            <bindingRedirect oldVersion="0.0.0.0-4.0.5.0" newVersion="4.0.5.0" />
        </dependentAssembly>
    </assemblyBinding>
</runtime>

```

## Update the root web configuration file

{% hint style="warning" %}
This step is **mandatory** when upgrading to version 9.2.2 (9.2 Beta 3) or later, including if you're upgrading from version 9.2.0 (9.2 Beta 1) or 9.2.1 (9.2 Beta 2) and previously updated the root `web.config` file when you upgraded to that version.
{% endhint %}

You must update your site's root `web.config` file with the new URL Rewrite rules.

First, make sure the [URL Rewrite](https://www.iis.net/downloads/microsoft/url-rewrite) tool is installed on your WorkflowGen server.

There are two sample files provided in the installation pack.

* If your WorkflowGen site uses the `/wfgen` path in its URL (e.g. `https://yoursite/wfgen`), refer to the `Inetpub\wwwroot\web.config` (in the manual installation pack) or `Inetpub\wwwroot\web.config.sample` sample file (in the update pack) for the new rules.
* If your WorkflowGen site does NOT use the `/wfgen` path in its URL (e.g. `https://yoursite`), refer to the `Inetpub\wwwroot\web.config.without-wfgen` sample file for the new rules.

## Update the `login.aspx` sample file (custom authentication only)

As of WorkflowGen 9.2.0, If you're using **custom form authentication** with a login page created based on the provided `/wfgen/login.aspx` sample template, you need to update the login page file. To do this:

1. Open your WorkflowGen site's `/wfgen/login.aspx` file (which might have been renamed).
2. Replace the `redirectToUrl = "/wfgen/show.aspx?QUERY=WELCOME";` line with `redirectToUrl = "/wfgen/dashboard";`.

## Update Form Designer webforms for versions 8 and later

As of WorkflowGen version 8, the `WorkflowGen.My.Web.UI.WebControls.dll` assembly has been merged into `WorkflowGen.My.dll`. This breaking change impacts webforms created in the Form Designer and the webforms' `\bin` folders, so you must perform one of the following procedures:

### Method 1: Use the provided PowerShell script

Run the `\update\configuration\update-webforms-wfg-my-assembly.ps1` script in PowerShell inside the `\wfgen\wfapps\webforms\` folder. This will automatically update your ASPX webforms and delete deprecated files and folders.

{% hint style="warning" %}
This script requires **PowerShell version 7.0 or later**.

It will update all `.aspx` files located in the `\webforms` folder, including those not managed by the Form Designer. If you have custom webforms in this folder that use another version of `WorkflowGen.My.dll`, then you should skip the changes to these `.aspx` files. You can do this by moving these files to a temporary folder before running the script, and then copying them back to the original folder.
{% endhint %}

#### 📌 Usage example

```bash
.\update-webforms-wfg-my-assembly.ps1 -Path "c:\inetpub\wwwroot\wfgen\wfapps\webforms" -Verbose
```

### Method 2: Manually

1. Delete the following files and folders from the`\wfgen\wfapps\webforms\bin\` folder:
   * `WorkflowGen.My.Web.UI.WebControls.dll`
   * `WorkflowGen.My.Web.Handlers.dll`
   * `\de`
   * `\fr`
   * `\hu`
   * `\pl`
2. Upgrade each of your webforms created in the Form Designer, either by re-saving them or by manually replacing the `<%@ Register Assembly="WorkflowGen.My.Web.UI.WebControls" ... %>` tag with `<%@ Register Assembly="WorkflowGen.My" ... %>` inside each of your `.aspx` files.

## Update the WorkflowGen database

Run the SQL scripts listed below in order, starting with your current version of WorkflowGen.

{% hint style="warning" %}
This section has been divided to provide a quicker reference for clients upgrading from **version 8.0.0 and later**. If you're upgrading from **version 7.22.15 or earlier**, see the [WorkflowGen Legacy Upgrade](https://docs.workflowgen.com/upgrade/10.0.3/workflowgen-upgrade/legacy-upgrade) section and run the required database update scripts based on the version from which you're upgrading, then return to this section and continue with the rest of the required scripts.
{% endhint %}

{% hint style="info" %}
Oracle database is no longer supported as of WorkflowGen 7.16.0.
{% endhint %}

#### For versions 8.0.1 and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V8-0-2.sql` database update script in your SQL Server Management Studio tool.

#### For versions 8.0.2 and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V8-0-3.sql` database update script in your SQL Server Management Studio tool.

#### For versions 8.0.x and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V8-1-0.sql` database update script in your SQL Server Management Studio tool.

#### For versions 8.1.3 and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V8-2-0.sql` database update script in your SQL Server Management Studio tool.

#### For versions 8.2.4 and earlier or version 9.0.0 Beta (v9 Beta 1)

Launch the `Update\Databases\MsSQLServer\Update_WFG-V9-0-1.sql` database update script in your SQL Server Management Studio tool.

#### For versions 9.0.1 Beta (v9 Beta 2) and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V9-0-2.sql` database update script in your SQL Server Management Studio tool.

#### For versions 9.0.2 Beta (v9 Beta 3) and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V9-0-3.sql` database update script in your SQL Server Management Studio tool.

#### For versions 9.0.7 and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V9-1-0.sql` database update script in your SQL Server Management Studio tool.

#### For versions 9.2.5 and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V9-2-6.sql` database update script in your SQL Server Management Studio tool.

#### For versions 9.2.7 and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V9-2-8.sql` database update script in your SQL Server Management Studio tool.

#### For versions 9.2.11 and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V9-3-0.sql` database update script in your SQL Server Management Studio tool.

#### For all 9.x.x versions and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V10-0-0.sql` database update script in your SQL Server Management Studio tool.

⚠️ **Important:** If you've changed the language code in the `web.config` parameter `GenerateChunksLanguageCode` (default is `0` for Neutral) for full-text search, you must manually update the language code in the `Update_WFG-V10-0-0.sql` script. If you're creating a new **WorkflowGen** database, update `Create_WFG_SQL_Indexes.sql` instead. The language code must match the new `GenerateChunksLanguageCode` value. For example, use `1033` for English or `1036` for French:

```sql
CREATE FULLTEXT INDEX ON WFDATASET_CHUNK
(
    CHUNK LANGUAGE 1033 -- English
)
KEY INDEX PK_CHUNK
ON WFDATASET_CATALOG
```

To retrieve the full list of supported language codes, run the following SQL query in **SQL Server Management Studio (SSMS):**

```sql
select * from sys.fulltext_languages;
```

#### For versions 10.0.0 (v10 Preview 1) and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V10-0-1.sql` database update script in your SQL Server Management Studio tool.

#### For versions 10.0.1 (v10 Preview 2) and earlier

Launch the `Update\Databases\MsSQLServer\Update_WFG-V10-0-2.sql` database update script in your SQL Server Management Studio tool.

#### For version 10.0.2 (v10 Prevew 3)

There's no database update script to run.

## Configure IIS

{% hint style="warning" %}
Domain users and the Windows accounts used to run the WorkflowGen IIS application pool and Engine service must have read and write permissions for the `\wfgen\app_data` folder.
{% endhint %}

### Update or create the application pool in .NET 4

The WorkflowGen website and web applications must now use an application pool in .NET 4. If this hasn't already been configured, do the following:

1. Install .NET Framework 4 on the server, if it's not already installed.<br>
2. Update the existing application pool or create a new application pool using .NET Framework 4 for:
   * the WorkflowGen website
   * `\wfgen`
   * `\wfgen\wfapps\webforms` (create this IIS web application if it isn’t already created)
   * `\wfgen\ws` <br>
3. If your application pool is set to use **Classic Managed Pipeline Mode**, make sure ASP.NET v4.0.30319 is set to `Allowed` in the IIS manager **ISAPI and CGI Restrictions** list.

## WorkflowGen Node.js-based web applications

To use the GraphQL, incoming webhooks, OpenID Connect Auth, and SCIM APIs, you must first install the following requirements:

* [Node.js v22.20.0 LTS](https://nodejs.org/download/release/v22.20.0/)
* [iisnode](https://github.com/Azure/iisnode/releases/tag/v0.2.21)
* [IIS URL Rewrite](https://www.iis.net/downloads/microsoft/url-rewrite)
* [Visual C++ Redistributable](https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads)\
  ✏️ **Note:** This library is required if you encounter the error `The specified module could not be found` regarding the `edge` and `edge-js` libraries when accessing the `/wfgen/graphql`, `/wfgen/hooks`, or `/wfgen/scim` web apps.

{% hint style="info" %}

* Delete each Node.js-based application's `node_modules` folder (located under `\wfgen\auth`, `\wfgen\graphql`, `\wfgen\hooks`, and `\wfgen\scim`) before copying the files from the upgrade pack.
* After enabling GraphQL, incoming webhooks, OpenID Connect Auth, or SCIM, the WorkflowGen DLLs will be in use by Node.js, so they'll be locked from being updated. In order to update the DLLs, it's necessary to stop IIS.
  {% endhint %}

### To enable WorkflowGen GraphQL:

1. In IIS, convert `/wfgen/graphql` to an application with a .NET 4 application pool (integrated pipeline).<br>
2. Configure the GraphQL application authentication mode:
   * **For Basic authentication:** Enable Basic authentication.
   * **For WorkflowGen Applicative authentication:**
     * Make sure the `/wfgen` web application already has WorkflowGen Applicative authentication enabled.
     * Enable Anonymous authentication.<br>
3. Update the WorkflowGen `web.config` file with the following parameters used by GraphQL:

   ```html
   <add key="GraphqlMaxPageSize" value="100" />
   <add key="GraphqlMaxBatchSize" value="1000" />
   <add key="GraphqlDefaultPageNumber" value="1" />
   <add key="GraphqlDefaultPageSize" value="30" />
   <add key="GraphqlGraphiqlEnabled" value="N" />
   <add key="GraphqlLoadersCacheEnabled" value="Y" />
   <add key="GraphqlDebugEnabled" value="N" />
   <add key="GraphqlQueryTimeout" value="90000" />
   <add key="GraphqlOperationTimeout" value="30000" />
   <add key="GraphqlMaxOperationCount" value="10000" />
   <add key="GraphqlMaxInputFileSize" value="10240" />
   <add key="GraphqlMaxInputFileContentSize" value="0" />
   <add key="GraphqlInputFileDownloadTimeout" value="100000" />
   <add key="GraphqlInputFileAllowedFolders" value="" />
   <add key="GraphqlInputFileAllowedHttpUrls" value="" />
   ```

### To enable WorkflowGen incoming webhooks:

1. Update the WorkflowGen `web.config` file with the following parameters used by incoming webhooks:

   ```html
   <add key="HooksDebugEnabled" value="N" />
   <add key="HooksOperationTimeout" value="30000" />
   <add key="HooksMaxInputFileSize" value="10240" />
   <add key="HooksMaxInputFileContentSize" value="0" />
   <add key="HooksInputFileDownloadTimeout" value="100000" />
   <add key="HooksInputFileAllowedFolders" value="" />
   <add key="HooksInputFileAllowedHttpUrls" value="" />
   ```
2. In IIS, convert `/wfgen/hooks` to an application with a .NET 4 application pool (integrated pipeline), and configure the hook application in **Anonymous** authentication mode.

{% hint style="info" %}
If your WorkflowGen is configured to use WorkflowGen Applicative authentication or a custom authentication, you must remove the authentication module from the `/hooks/web.config` file as follows:<br>

**For WorkflowGen Applicative authentication:**

```html
<location path="hooks" inheritInChildApplications="false">
    <system.webServer>
        <modules>
            <remove name="ApplicationSecurityAuthenticationModule" />
        </modules>
    </system.webServer>
</location>
```

\
**For Custom authentication:**

```html
<location path="hooks" inheritInChildApplications="false">
    <system.webServer>
        <modules>
            <remove name="MyCustomAuthModule" />
        </modules>
    </system.webServer>
</location>
```

{% endhint %}

### **To enable WorkflowGen SCIM:**

In IIS, convert `/wfgen/scim` to an application with a .NET 4 application pool (integrated pipeline), and configure the application in **Anonymous** authentication mode.

{% hint style="info" %}
If your WorkflowGen is configured to use WorkflowGen Applicative authentication or a custom authentication, you must remove the authentication module from the `/scim/web.config` file as follows:

\
**For WorkflowGen Applicative authentication:**

```html
<location path="scim" inheritInChildApplications="false">
    <system.webServer>
        <modules>
            <remove name="ApplicationSecurityAuthenticationModule" />
        </modules>
    </system.webServer>
</location>
```

\
**For Custom authentication:**

```html
<location path="scim" inheritInChildApplications="false">
    <system.webServer>
        <modules>
            <remove name="MyCustomAuthModule" />
        </modules>
    </system.webServer>
</location>
```

{% endhint %}

### **To enable WorkflowGen OpenID Connect Auth:**

In IIS, convert `/wfgen/auth` to an application with a .NET 4 application pool (integrated pipeline), and configure the application in **Anonymous** authentication mode.

{% hint style="info" %}
If your WorkflowGen is configured to use WorkflowGen Applicative authentication or a custom authentication, you must remove the authentication module from the `\auth\web.config` file as follows:

\
**For WorkflowGen Applicative authentication:**

```html
<location path="auth" inheritInChildApplications="false">
    <system.webServer>
        <modules>
            <remove name="ApplicationSecurityAuthenticationModule" />
        </modules>
    </system.webServer>
</location>
```

\
**For Custom authentication:**

```html
<location path="auth" inheritInChildApplications="false">
    <system.webServer>
        <modules>
            <remove name="MyCustomAuthModule" />
        </modules>
    </system.webServer>
</location>
```

{% endhint %}

## Restart the WorkflowGen server

Reboot your WorkflowGen web server.

## New location of workflow application temporary and log files

The following workflow applications store their files in these new locations:

* EFORMASPX: `\wfgen\App_Data\Files\EFormAspx`
* XMLTODATABASE: `\wfgen\App_Data\LogFiles\XmlToDatabase`
* XMLTRANS: `\wfgen\App_Data\Files\XmlTrans` and `\wfgen\App_Data\LogFiles\XmlTrans`
