共用方式為


設定初始群組、小組、成員和權限

使用群組和使用權限的外掛程式檔案,可以設定 Team 專案的初始安全性設定。 您可以定義建立安全性群組,巢狀群組,定義群組的工作完成這項作業,在小組,設定初始小組設定,指定群組的成員,並允許或拒絕特定使用權限的群組。 除了執行這些工作之外,您還可以指定集合層級、專案層級和專案類別的初始安全性設定。

Microsoft 程序範本會將數個使用權限指派給預設群組。 您可以自訂群組和使用權限的外掛程式檔案,以修改這些指派。 如需這個外掛程式的詳細資訊,請參閱使用群組和權限外掛程式定義群組、小組和權限

本主題內容

  • 使用群組、成員和群組使用權限項目,將使用權限定義和指派給群組

  • Team Foundation Server 中定義的群組巨集和預設群組

  • 巢狀群組以及將成員指派給群組

  • 定義小組

  • 指派集合層級使用權限

  • 指派專案層級使用權限

  • 指派控制區域路徑的使用權限

  • 指派控制反覆項目路徑的使用權限

如需如何設定 Team 專案功能區域 (例如 Team Foundation Build、Team Foundation 版本控制和 Visual Studio Lab Management) 之初始安全性設定的詳細資訊,請參閱控制功能區域的存取權

如需如何自訂工作項目類型以允許或拒絕存取群組或使用者的詳細資訊,請參閱管理用於建立或修改工作項目的權限

如需如何管理 Visual Studio Application Lifecycle Management (ALM) 之使用者和群組以及控制存取權的詳細資訊,請參閱設定使用者、群組和使用權限

定義並指派使用權限給使用群組的群組、成員和群組權限項目

您可以使用 groupmember 項目,在 Team Foundation Server 中指定新安全性群組,以及將成員加入至該群組。 您可以使用群組 permission 項目,將使用權限指派給群組及該群組的成員。 您必須在其對應容器項目內封裝上述所有項目:groupsmemberspermissions。 您可以使用上述所有項目的下列語法結構:

<group name="Group Name" description="Description of Group"></group>
<member name="MemberName"></member>
<permission name="PermissionName" class="ClassName" allow="True | False"/>

下表描述 groupmember 和群組 permission 項目的屬性。 這些項目只能用於群組和使用權限外掛程式檔案。

元素

屬性

描述

group

name

指定所建立的群組名稱。

isTeam

表示群組是小組 ([true]) 或沒有 (false)。

description

向其他使用者描述群組用途。

member

name

指定加入為另一個群組成員的群組名稱。 您可以建立群組,並將它們預先填入下列任何類型的成員:

  • Team Foundation Server 中定義的預設群組

  • 先前已在 groupsandpermissions.xml 檔案中定義的專案群組 (例如,[$$PROJECTNAME$$]\Contributors)

  • Active Directory 中定義的群組和使用者,可以使用下列格式指定:

    • 網域\使用者名稱

    • 網域\群組名稱

如需在指定預設群組時所使用格式的詳細資訊,請參閱本主題後面的 Team Foundation Server 中定義的預設群組。

permission

name

識別所套用的權限。 如需所支援使用權限的清單,請參閱本主題後面的下列各節:

  • 指派集合層級使用權限

  • 指派專案層級使用權限

  • 指派控制區域和反覆項目層級的使用權限

class

識別授與群組使用權限的類別或區域。 下列是有效值:

  • NAMESPACE:指定集合層級使用權限。

  • PROJECT:指定專案層級使用權限。

  • CSS_NODE:指定用於檢視和管理 Team 專案之區域路徑的使用權限。

  • ITERATION_NODE:指定用於檢視和管理 Team 專案之反覆項目路徑的使用權限。

allow

使用 truefalse 值,指出允許還是拒絕使用權限。

path

識別套用使用權限的區域路徑或反覆項目路徑的節點。 只有當 class 設定為 CSS_NODE 或 ITERATION_NODE 時,這個屬性才適用。

Team Foundation Server 中定義的群組巨集和預設群組

下表列出的巨集,可用來指定 Team Foundation Server 中所定義的預設群組。

注意事項注意事項

您只能在群組和使用權限的外掛程式中指定下表的巨集。使用外掛程式進行組建、版本控制或 Lab Management 以指派使用權限時,無法指定這些巨集。

預設群組

巨集

Project Collection Administrators

[SERVER]\$$PROJECTCOLLECTIONADMINGROUP$$

[SERVER]\$$TEAMFOUNDATIONADMINGROUP$$

$$集合管理群組$$

Project Collection Service Accounts

[SERVER]\$$PROJECTCOLLECTIONSERVICESGROUP$$

Project Collection Build Service Accounts

[SERVER]\$$PROJECTCOLLECTIONBUILDSERVICESGROUP$$

$$集合建立服務群組$$

Project Collection Build Administrators

[SERVER]\$$PROJECTCOLLECTIONBUILDADMINSGROUP$$

$$集合建立管理員群組$$

Project Administrators

$$PROJECTADMINGROUP$$

[$$PROJECTNAME$$]\$$PROJECTADMINGROUP$$

[$$PROJECTNAME$$]\產生器

專案建立者

$$CREATOR OWNER$$

@creator

預設小組

@defaultTeam

將群組設為巢狀以及將成員指派給群組範例

下列範例顯示如何設定命名為 TestGroup1、TestGroup2 和 TestGroup3 的群組。 在此範例中,您會將 TestGroup1 加入為 TestGroup2 的成員。 若要讓此程式碼有效,您必須先定義 TestGroup1,再定義 TestGroup2。

<task id="GroupCreation1"> 
    <taskXml>
      <groups>
        <group name="TestGroup1" description="Test group 1.  Contains no members out of the box.">
          <permissions>
            <permission name="GENERIC_READ" class="PROJECT" allow="true" />
          </permissions>
        </group>
        <group name="TestGroup2" description="Test group 2.  Contains TestGroup1 and Project Administrators.">
          <permissions>
            <permission name="GENERIC_READ" class="PROJECT" allow="true" />
          </permissions>
          <members>
            <member name="TestGroup1" />
            <member name="$$PROJECTADMINGROUP$$" />
          </members>
        </group>
        <group name="TestGroup3" description="Test group 3. Contains DOMAIN\USER, DOMAIN\GROUP, Project Administrators, and Project Collection Build Service Accounts.">
          <permissions>
            <permission name="GENERIC_READ" class="PROJECT" allow="true" />
          </permissions>
          <members>
            <member name="DOMAIN\USER" />
            <member name="DOMAIN\GROUP" />
            <member name="[$$PROJECTNAME$$]\$$PROJECTADMINGROUP$$" />
            <member name="[SERVER]\$$PROJECTCOLLECTIONBUILDSERVICESGROUP$$" />
          </members>
        </group>
      </groups>
    </taskXml>
</task>

定義小組

除了建立群組之外,您還可以身為小組工作群組。 建立 Team 專案也會建立預設小組。 如果您有想要個別組織其工作與其他小組的幾個小組,則您可以定義在群組和權限外掛程式檔案中的這些小組,也可以設定屬性,在您建立 Team 專案之後。 請參閱 小組使用者入門

下列範例顯示如何以為小組設定群組。 在此範例中,您可以指定群組,夢投影片小組,身為小組並將 Team 專案建立者做為小組的成員。 您為小組指定的任何反覆項目路徑在 Classification 外掛程式檔案必須定義。 請參閱 在 Classification 外掛程式中定義初始區域和反覆項目

<group name="Dream Team" isTeam="true" description="Next generation work">
   <permissions>
      <permission name="GENERIC_READ" class="PROJECT" allow="true" />
   </permissions>
   <members>
      <member name="@creator"/>
   </members>
   <teamSettings areaPath="Area">
      <iterationPaths backlogPath="Iteration">
         <iterationPath path="Release 1\Sprint 1" />
         <iterationPath path="Release 1\Sprint 2" />
         <iterationPath path="Release 1\Sprint 3" />
         <iterationPath path="Release 1\Sprint 4" />
         <iterationPath path="Release 1\Sprint 5" />
         <iterationPath path="Release 1\Sprint 6" />
      </iterationPaths>
   </teamSettings>
</group>

指派集合層級使用權限

您可以使用群組 permission 項目和 NAMESPACE 類別,指派集合層級使用權限。 這些使用權限控制可在 Team 專案中使用之資源的存取權。 您只能針對下列類別的使用者,設定集合層級使用權限:

  • 集合層級使用者和群組 (例如 Project Collection Administrators)

  • 執行 Team Foundation 的伺服器上已加入至集合層級的專案層級群組

  • 您所建立並加入至集合層級的自訂群組

如需在指定群組時所使用的格式,請參閱本主題前面的 Team Foundation Server 中定義的預設群組。

注意事項注意事項

設定這些使用權限的方式如下:以滑鼠右鍵按一下 Team Explorer中的伺服器,然後按一下 [安全性];開啟或使用 Team Foundation 的管理主控台;或是使用 TFSSecuritytf 命令列工具。如需詳細資訊,請參閱Collection-Level Groups使用 TFSSecurity 變更群組和權限Permission Command

下列範例顯示如何將集合層級使用權限授與 Team 專案的專案管理員。

<group name="PROJECTADMINGROUP" description="Members of this group can add, modify, and delete items within the team project.">
   <permissions>
       <permission name="GENERIC_READ" class="NAMESPACE" allow="true" />
       <permission name="WORK_ITEM_WRITE" class="NAMESPACE" allow="true" />
       <permission name="MANAGE_LINK_TYPES" class="NAMESPACE" allow="true" />
       <permission name="MANAGE_TEMPLATE" class="NAMESPACE" allow="true" />
       <permission name="MANAGE_TEST_CONTROLLERS" class="NAMESPACE" allow="true" />
    </permissions>
</group>

下表描述您可以進行指派的集合層級使用權限。

注意事項注意事項

在 MSF 流程範本中,預設不會指派任何集合層級使用權限。

使用權限

描述

DIAGNOSTIC_TRACE

修改追蹤設定。 可以變更追蹤設定,以收集更詳細的 Team Foundation Server Web 服務診斷資訊。

CREATE_PROJECTS

建立新專案。 可以在 Team 專案集合中建立專案。

GENERIC_WRITE

編輯集合層級資訊。 可以針對 Team 專案集合中的使用者和群組,編輯集合層級使用權限。 具有這個使用權限的使用者可以執行下列工作:

  • 從 Team Foundation Server 的集合中加入、移除或重新命名集合層級應用程式群組。

    注意事項注意事項
    您無法移除預設的集合層級群組 (例如 Project Collection Administrators)。
  • 加入或移除 Windows 使用者或 Team Foundation Server 中另一個應用程式群組 (伺服器層級) 中的使用者或群組。

  • 變更使用者和群組的集合層級使用權限。

此外,除非其他使用權限明確拒絕具有這個使用權限的使用者存取權,否則這些使用者可以修改版本控制的使用權限,而且具有版本控制中所有檔案的寫入存取權。

MANAGE_TEMPLATE

管理流程範本。 可以對 Team 專案集合下載、建立、編輯和上載流程範本。

MANAGE_TEST_CONTROLLERS

管理測試控制器。 可以註冊和取消註冊 Team 專案集合的測試控制器。

MANAGE_LINK_TYPES

管理工作項目連結類型。 可以加入、移除和變更工作項目的連結類型。

GENERIC_READ

檢視集合層級資訊。 可以檢視集合層級群組的成員資格以及這些使用者的使用權限。

指派專案層級使用權限

您只能在群組和使用權限外掛程式檔案中指派專案層級使用權限。 您可以使用群組 permission 項目和 PROJECT 類別,指派這些使用權限。 這些使用權限控制單一專案資源的存取權。 您可以將存取權授與 Windows 中的使用者和群組、Team Foundation 中的群組,以及您先前在「群組和權限」外掛程式檔案中定義的群組。 如需在指定群組時所使用的格式,請參閱本主題前面的 Team Foundation Server 中定義的預設群組。

注意事項注意事項

在建立 Team 專案之後,以滑鼠右鍵按一下專案,並依序按一下 [Team 專案設定] 和 [安全性],就可以在 Team Explorer中設定這些使用權限。您也可以使用 TFSSecurity 命令列工具來設定這些使用權限。如需詳細資訊,請參閱管理使用權限

下列範例會示範如何將許多使用權限授與 Team 專案的 [Contributors] 群組。

<group name="Contributors" description="Members of this group can add, modify, and delete items within the team project.">
   <permissions>
      <permission name="GENERIC_READ" class="PROJECT" allow="true" />
      <permission name="DELETE_TEST_RESULTS" class="PROJECT" allow="true" />
       <permission name="PUBLISH_TEST_RESULTS" class="PROJECT" allow="true" />
       <permission name="VIEW_TEST_RESULTS" class="PROJECT" allow="true" />
       <permission name="MANAGE_TEST_ENVIRONMENTS" class="PROJECT" allow="true" />
      <permission name="MANAGE_TEST_CONFIGURATIONS" class="PROJECT" allow="true" />
   </permissions>
</group>

下表描述您可以指派的專案層級使用權限,並指出在 MSF 流程範本中進行的預設指派。

使用權限

描述

Readers

Contributors

組建系統管理員

GENERIC_READ

檢視專案層級資訊。 可以檢視專案層級群組的成員資格以及這些成員的使用權限。

核取標記 核取標記 核取標記

VIEW_TEST_RESULTS

檢視測試回合。 可以檢視此節點中的測試計劃。

核取標記 核取標記 核取標記

MANAGE_TEST_CONFIGURATIONS

管理測試組態。 可以建立和刪除 Team 專案的測試組態。

核取標記 核取標記

MANAGE_TEST_ENVIRONMENTS

管理測試環境。 可以建立和刪除 Team 專案的測試環境。

核取標記 核取標記

PUBLISH_TEST_RESULTS

建立測試回合。 可以加入和移除 Team 專案的測試結果,以及加入或修改 Team 專案的測試回合。

核取標記 核取標記

DELETE_TEST_RESULTS

刪除測試回合。 可以刪除 Team 專案的排程測試。

核取標記 核取標記

DELETE

刪除 Team 專案。 可以從 Team Foundation Server 中刪除使用者擁有此使用權限的專案。

GENERIC_WRITE

編輯專案層級資訊。 可以編輯 Team Foundation Server 中使用者和群組的專案層級使用權限。

指派控制區域路徑的使用權限

您可以使用群組 permission 項目和 CSS_NODE 類別,指派用以控制區域定義之存取權的使用權限。 這些使用權限控制單一專案之類別結構的存取權。 您可以將存取權授與 Windows 中的使用者和群組、Team Foundation 中的群組,以及您先前在「群組和權限」外掛程式檔案中定義的群組。 如需在指定群組時所使用格式的詳細資訊,請參閱本主題前面的 Team Foundation Server 中定義的預設群組。

注意事項注意事項

在建立小組專案之後,以滑鼠右鍵按一下專案,並依序按一下 [區域和迭代項目]、[迭代項目] 索引標籤和 [安全性],就可以在 Team Explorer中設定這些使用權限。您可以將使用權限指派給階層內不同層級的節點。您也可以使用 TFSSecurity 命令列工具來設定這些使用權限。如需詳細資訊,請參閱管理使用權限

下列範例會示範如何將許多使用權限授與 Team 專案的 [Contributors] 群組。

<group name="Contributors" description="Members of this group can add, modify, and delete items within the team project.">
   <permissions>
      <permission name="GENERIC_READ" class="CSS_NODE" allow="true" />
      <permission name="WORK_ITEM_READ" class="CSS_NODE" allow="true" />
      <permission name="WORK_ITEM_WRITE" class="CSS_NODE" allow="true" />
      <permission name="MANAGE_TEST_PLANS" class="CSS_NODE" allow="true" />
   </permissions>
</group>

下表描述您可以指派的使用權限,用以控制專案區域和反覆項目節點之階層結構的存取權。 此表格也會指出在 MSF 流程範本中進行的預設指派。

注意事項注意事項

追蹤工作項目的部分作業需要多個使用權限。例如,您需要有多項使用權限才能刪除節點。

使用權限

描述

Readers

Contributors

組建系統管理員

GENERIC_READ

檢視此節點。 可以檢視區域節點的安全性設定。

核取標記 核取標記 核取標記

WORK_ITEM_READ

檢視此節點中的工作項目。 可以檢視 (但不能變更) 指派給區域節點的工作項目。

核取標記 核取標記 核取標記

WORK_ITEM_WRITE

編輯此節點中的工作項目。 可以編輯指派給區域節點的工作項目。

核取標記 核取標記

MANAGE_TEST_PLANS

管理測試計劃。 可以建立和編輯指派給區域節點的測試計劃。 如果測試計劃尚未執行,則也可以刪除它們。

核取標記 核取標記

CREATE_CHILDREN

建立並排列子節點的順序。 可以建立區域節點。 同時具有這個使用權限和 GENERIC_WRITE 使用權限的使用者,可以移動或重新排列任何子區域節點。

DELETE

刪除此節點。 可以刪除區域節點。

擁有這個使用權限,同時針對另一個節點具有 GENERIC_WRITE 使用權限的使用者可以刪除區域節點,並重新分類所刪除節點中的現有工作項目。 如果所刪除的節點具有子節點,則也會一併刪除那些節點。

GENERIC_WRITE

編輯此節點。 可以設定區域節點的使用權限,以及重新命名區域節點。

指派控制反覆項目路徑的使用權限

您可以使用群組 permission 項目和 ITERATION_NODE 類別,指派用以控制反覆項目路徑之存取權的使用權限。 這些使用權限控制單一專案之里程碑版本或反覆項目的存取權。 您可以將存取權授與 Windows 中的使用者和群組、Team Foundation 中的群組,以及您先前在「群組和權限」外掛程式檔案中定義的群組。 如需在指定群組時所使用格式的詳細資訊,請參閱本主題前面的 Team Foundation Server 中定義的預設群組。

注意事項注意事項

在建立 Team 專案之後,以滑鼠右鍵按一下專案,並依序按一下 [區域和反覆項目]、[反覆項目] 索引標籤和 [安全性],就可以在 Team Explorer中設定這些使用權限。您可以將使用權限指派給階層內不同層級的節點。您也可以使用 TFSSecurity 命令列工具來設定這些使用權限。如需詳細資訊,請參閱管理使用權限

下列範例顯示如何將數個使用權限授與 Team 專案的 Contributors 群組:

<group name="Contributors" description="Members of this group can add, modify, and delete items within the team project.">
   <permissions>
      <permission name="GENERIC_READ" class="ITERATION_NODE" allow="true" />
      <permission name="GENERIC_WRITE" class="ITERATION_NODE" allow="true" />
      <permission name="CREATE_CHILDREN" class="ITERATION_NODE" allow="true" />
   </permissions>
</group>

下表描述您可以指派的使用權限,用以控制專案反覆項目節點之階層結構的存取權。 因為MSF程序範本未指定任何ITERATION_NODE使用權限,所以所有小組成員都可以建立、檢視和刪除迭代項目節點。

注意事項注意事項

追蹤工作項目的部分作業需要多個使用權限。例如,您需要有多項使用權限才能刪除節點。

使用權限

描述

GENERIC_READ

檢視此節點。 可以檢視節點的安全性設定。

CREATE_CHILDREN

建立並排列子節點的順序。 可以建立反覆項目節點。 同時具有這個使用權限和 GENERIC_WRITE 使用權限的使用者,可以移動或重新排列任何反覆項目節點。

DELETE

刪除此節點。 可以刪除反覆項目節點。

擁有這個使用權限,同時針對另一個節點具有 GENERIC_WRITE 使用權限的使用者可以刪除反覆項目節點,並重新分類所刪除節點中的現有工作項目。 如果所刪除的節點具有子節點,則也會一併刪除那些節點。

GENERIC_WRITE

編輯此節點。 可以設定反覆項目節點的使用權限,以及重新命名節點。

請參閱

概念

使用群組和權限外掛程式定義群組、小組和權限

控制功能區域的存取權

設定使用者、群組和使用權限

在流程範本中自訂功能區域

其他資源

管理用於建立或修改工作項目的權限

變更記錄

日期

記錄

原因

2012 年 8 月

如需定義小組的資訊。

補充資訊。