User mentions appear as Broken link after XML import

お困りですか?

アトラシアン コミュニティをご利用ください。

コミュニティに質問

プラットフォームについて: Data Center - この記事は、Data Center プラットフォームのアトラシアン製品に適用されます。

このナレッジベース記事は製品の Data Center バージョン用に作成されています。Data Center 固有ではない機能の Data Center ナレッジベースは、製品のサーバー バージョンでも動作する可能性はありますが、テストは行われていません。サーバー*製品のサポートは 2024 年 2 月 15 日に終了しました。サーバー製品を利用している場合は、アトラシアンのサーバー製品のサポート終了のお知らせページにて移行オプションをご確認ください。

*Fisheye および Crucible は除く

症状

After importing an XML backup into Confluence, user mentions will appear as a broken link for users that exist on both instances: Broken link.

This has been reported as a known bug: CONFSERVER-34994 - Mentions broken after space xml Import

診断

The problem is that the user keys associated to the user names are different between Confluence instances. User mentions using the old user keys will no longer work. To confirm that you are affected by this, please follow these steps:

  1. On a page with broken mentions on the target instance, click . . . in the top right-hand corner, and select View Storage Format. In your storage format, any references to user mentions will look like this:

    <p><ac:link><ri:user ri:userkey="ff8080814ba236dc014ba236f4e40001" /></ac:link></p>
    <p><ac:link><ri:user ri:userkey="ff8080814ba236dc014ba236f4e60002" /></ac:link></p>
  2. In the Confluence database on target instance:

    select * from user_mapping;

    Or, to view the user_key of the broken user to test:

     select * from user_mapping WHERE username='username';
  3. You will receive a list that looks like this, with either one row for each user queried.

                user_key             | username | lower_username 
    
    ----------------------------------+----------+----------------
    ff8080814ba236dc014ba239c8eb000d | username | username
    
    (1 row)
  4. Compare the user key with the one from the Storage Format. You will notice they are different.

ソリューション

To resolve this problem, we are going to modify the Confluence pages with the affected macro and replace the old user keys with the new ones. To do this we will need to have access to the database on the source instance, and the target instance where it was restored.

  1. Create a .csv file of the user_mapping table from the database of both the target and source instances. This is a example of how the content of the CSV file should look:

    ff80808147fe63530147fe6365d80001,username1,username1
    ff80808147fe63530147fe6365d90002,username2,username2
    ff80808147fe63530147fe6462e00004,username3,username3
  2. Download the following script: fixUserKeySqlGenerator.py

    1. If you're on SQL Server, use the following script for the appropriate syntax: SQLSERVERfixUserKeySqlGenerator.py

  3. Run the script, either from your local computer or the server. You may need to grant execution permission to the script to be able to run it.

    ./fixUserKeySqlGenerator.py Source_Instance_user_mapping.csv Target_Instance_user_mapping.csv

    The script will generate a list of SQL queries on the standard output. You will need to execute those queries in your new Confluence database to apply the changes.

  4. Confluence を終了します。

  5. Create a backup of your data before proceeding.

  6. Run the queries generated by the script in your Confluence database.
  7. Confluence を起動します。
  8. Check the broken pages, to ensure the script worked.


This script requires Python 2.6 or higher. If you run into an error, you may need to run using specifically python2.6:

# ./fixUserKeySqlGenerator.py Source_Instance_user_mapping.csv Target_Instance_user_mapping.csv
  File "./fixUserKeySqlGenerator.py", line 19
    with open(sys.argv[1], mode='r') as OldUsersCsv:
            ^
SyntaxError: invalid syntax

Thus:

 # python2.6 fixUserKeySqlGenerator.py Source_Instance_user_mapping.csv Target_Instance_user_mapping.csv

If you run into the below error, check for empty lines in the .csv files and remove it before running the script again.

# python2.6 fixUserKeySqlGeneratornew.py Source_Instance_user_mapping.csv Target_Instance_user_mapping.csv
Traceback (most recent call last):
  File "fixUserKeySqlGeneratornew.py", line 21, in <module>
    oldUsers = dict((rows[2].strip(),rows[0]) for rows in oldUsersFileReader)
  File "fixUserKeySqlGeneratornew.py", line 21, in <genexpr>
    oldUsers = dict((rows[2].strip(),rows[0]) for rows in oldUsersFileReader)
IndexError: list index out of range



最終更新日: 2025 年 1 月 23 日

この内容はお役に立ちましたか?

はい
いいえ
この記事についてのフィードバックを送信する
Powered by Confluence and Scroll Viewport.