Security Advisor
Exercises in Trust
Setting up forest trusts can be tricky. Here’s a step-by-step instruction guide.
- By Roberta Bragg
- 10/01/2003
In last month’s column I discussed the realities of trust relationships
in Windows Server 2003. This month, I’ll drop the pontification and provide
the plan.
I’m sure you’ve spent time deciding exactly what kind of a trust is necessary. Just because a forest trust is possible doesn’t mean you need to create one, when one or two external trusts will do. Even a forest trust can be limited by using selective authentication, but is this the right way to go? Only you can answer those questions.
There are three steps to trust building:
Prepare the landscape. The actual process of
creating an external trust is simple, if you’ve prepared the environment.
Create the trust. You’ll need your partner to
help with this one.
Grant users and groups access. This is the real
work; after all, the trust is just a requirement so this can be done.
Forestry
The trust creation process isn’t some mysterious process requiring special
charms and wizardry. The normal needs for network connectivity, name resolution
and proper authority form the basis on which the relationship is built.
Many failed trust relationships are the results of ignoring these areas,
so spending a little time on them up front may save hours of troubleshooting.
Before a forest trust can be consummated, these things must be true:
DNS infrastructure must be correctly configured.
Both forests must be Windows 2003 forests.
All domain controllers must be running Windows 2003.
Both forests must be at Windows 2003-level functionality.
Participants on both sides of the trust must be domain administrators
in the root domain of the forest, members of the Enterprise Admins group
or delegated the authority to create a trust.
Incoming Trust Builders, a new group in Windows 2003, empowers members
to create one-way incoming forest trusts.
To create the forest trust from one location, you must have proper credentials
for the partner forest.
Time must be synchronized between the two forests.
One other thing: Name resolution is an essential ingredient of creating
a forest trust and, of course, for use of the trust relationship to access
resources in partner trusts. I’m assuming your DNS infrastructure for
both forests is correctly configured. If you’re having DNS problems, stop
right here—get DNS straightened out before attempting to create a forest
trust.
Ensuring Correct Functional Level
You don’t need every server in the forest to be Windows 2003 to create
a forest trust. However, you do need to make sure all DCs in all domains
in both forests are running Windows 2003. Furthermore, both forests must
be at Windows 2003 functional level.
The first step is easy, if costly and time consuming in a multi-domain
forest. In a test lab, we can simply build our forests that way. But like
Windows 2000 native mode, Windows 2003 forest functional level doesn’t
magically happen just because all of our DCs are running Windows 2003.
Setting forest functional level is a two-step process. First, each domain
must be set to Windows 2003 functional level, and then the forest must
be set.
Remove NT 4.0
First, ensure that no Windows NT 4.0 DCs remain. If you don’t, you risk
orphaning those DCs and providing yourself with a troubleshooting headache.
When the functional level of the domain is raised, there’s no failsafe
that stops the process if NT 4.0 DCs are still part of the domain. Instead,
replication with the NT 4.0 DCs just stops. This is true whether you’re
raising the level to Win 2K native or Windows 2003.
Create the Trust
You have to go through the exercises just described to prepare the forest
for a forest trust. However, if an external trust is all you need, you
can create one without raising the forest functional level. You can also
create external trusts between a Win2K domain in another forest and the
Windows 2003 domain or between Windows 2003 and an NT 4.0 domain. If,
however, you want to use Selective authentication within the trusting
domain, that domain must be at the Windows 2003 domain functional level.
Remember, an external trust is—like it is in Win2K—a one-way, non-transitive
trust that only exists between the two domains. To make trusts go both
ways, you must create two trusts, one in each direction. Instructions
for both types of trust, external and forest, follow.
External Trust
To create an external trust that uses selective authentication, determine
which domain in each forest will participate. Microsoft documentation
and the Trust Wizard call the domain from which you begin the trust process
the local domain. The other domain is called the specified domain. In
this example, we’ll create a one-way trust between tailspintoys.com and
wingtiptoys.com. Since I’ll run the wizard from a DC in tailspintoys.com,
it’s the local domain, while wingtiptoys.com is the specified domain:
1: Log on as a member of Domain Admins for tailspintoys.com.
2: Open Start, Administrative Tools, Active Directory Domains and Trusts.
3: Right-click the tailspintoys.com domain object and select Properties from the context menu.
4: Click the Trusts tab and then click New Trust.
5: On the Trust Wizard welcome page, click Next.
6: Enter the name of the domain to create a trust with wingtiptoys.com, then click Next.
7: On the Trust page, select External Trust and then click Next.
8: Select One-way, outgoing trust.
Remember, incoming and outgoing refer to the direction of trust. To put
it in NT 4.0 terms: The outgoing trust means the users in the specified
domain will be able to access resources in the local domain; the specified
domain is the trusted domain; and the local domain is the trusting domain.
Or, as the Trust Wizard puts it, “users in the specified domain, forest
or realm can be authenticated in this domain.” In our example, this means
that we’ll be able to give users in the Wingtiptoys.com domain access
to resources in the Tailspintoys.com domain. However, because we specified
a one-way trust, the users can’t be given access to resources in Wingtiptoys.
An interesting side effect of this new way of thinking is that for Wingtiptoys,
this trust is an incoming trust. If we were to create the trust using
the Wingtiptoys DC, or complete it from there, we’d create an incoming
trust. If this is confusing, think of it this way: We’re offering to trust
outsiders. We’re extending the boundaries of Tailspintoys trust outward.
However, from Wingtiptoys’ point of view, they’re getting in some more
resources.
(See Figure 1.)
|
Figure 1. Options for selecting the direction
of the trust. (Click image to view larger version.) |
In our case, we want a one-way trust relationship, but in Windows 2003, we could have chosen a two-way trust. In this case, users in both domains can be given access to resources in either domain.
9: Select the side of the trust to create. Since we’re running our own show, we choose both the local (Tailspintoys) and the external (Wingtiptoys) domains. If we had the credentials for only one domain, we’d choose local, and the Trust Wizard would need to be run at the other domain by an authorized administrator to complete the trust.
10: Next, enter the user name and password for a domain administrator in Wingtiptoys.
11: Finally, select the authentication scope. This is new in Windows 2003.
Selecting Selective authentication (Figure 2) allows access limitations for
Wingtip users for specified servers in the domain.
|
Figure 2. Choose Selective authentication to limit
user access from the trusted domain. (Click image to view larger version.) |
12: Note the summary and click Next twice.
13: Confirm the trust by clicking OK.
14: The trust property page should show the domain in the proper category as
shown in Figure 3.
|
Figure 3. Wingtiptoys.com, shown with an external trust
to Tailspintoys.com. |
Create a Forest Trust
To create a forest trust, there can’t be an already existing trust relationship
between the forests. So if you have an external trust with a forest and
want to change it to a forest trust, you’ll have to remove the external
trust first. That’s a simple process: Simply select the trust and remove
it. However, users who’ve been granted access to resources won’t be able
to use them until the forest trust is properly established. If you’re
following along, don’t forget to remove the external trust created in
the last exercise.
To create the forest trust:
1: Log on as a member of Domain Admins in the forest root domain of Tailspintoys (the local domain), then open Start, Administrative Tools, Active Directory Domains and Trusts.
2: Right-click the domain node for the forest root domain and select Properties from the context menu.
3: Select the Trust tab.
4: Click New Trust.
5: Enter the DNS name Wingtiptoys (the specified domain) for the name of the other forest.
6: Select Forest Trust, then Next.
7: Select the two-way for the Trust direction, then click Next.
8: On the Outgoing Trust Authentication Level, select Selective authentication and then click Next.
9: On the Incoming Trust Authentication Level page select Selective authentication and click Next.
10: Note the summary information, then click Next.
11: Confirm the incoming trust, then click Next.
12: Confirm the outgoing trust, then click Next.
13: Review Trust status, then click Next.
14: In the Trust Properties page, confirm that the specified domain name
is listed in the trusted (outgoing trusts) and trusting (incoming) trust
boxes (see Figure 4).
|
Figure 4. If you’ve done it right, Wingtiptoys
should be listed as both a trusted and trusting domain. |
Access Across Forest Boundaries
In an external trust, two domains in different forests develop a relationship
so that users in one or both domains can be given access to resources
in the other. The trust doesn’t provide this access, with the exception
of providing users in the trusted domain the ability to authenticate to
the trusting domain. In essence, the trusting domain accepts the word
of the trusted domain that the account is valid and the password is correct.
All other access must be granted.
While this seems to mean that users can’t gain access to the other domain’s resources until it’s granted, that’s not so. If users are authenticated to the trusting domain, they’re added to the Everyone group. In our example, the users from the Wingtiptoys domain, once authenticated to the Tailspintoys domain, can access resources and have the privileges granted to the Everyone group in Tailspintoys. It’s all very well to tell you to remove access for the Everyone group but, in reality, that’s quite difficult to do across all servers and workstations in the enterprise. Instead, to keep trust partners from inadvertently opening resources, choose Selective authentication.
After the external trust is built, “Permission to authentication” must be granted on every server to which Wingtiptoys users need to have access. Later, when the external trust is removed and a forest trust created, Selective authentication must be selected. In order to give access to users across the forest boundary, we have to give groups from the trusted domain “allowed to authenticate” to each domain in the forest where we want to allow this.
Remember to document your choice of Selective authentication and instruct admins on how to use the allowed to authenticate permission. It’s easy to give groups in the trusted domain this permission. For example, we’ll grant the Wingtiptoys\Accounting group allowed to authenticate permission to the Tailspintoys.com domain and to Server1, where a folder’s been set up for them to share information with Accountants at Tailspintoys.
1: Log on to a domain in the Tailspintoys domain.
2: Open Active Directory Users and Computers.
3: Select View, then click Advanced Features to select it.
4: Select the DC’s OU and right-click it, then Properties.
5: On the security page, click Add, then Location. Select Wingtiptoys.com.
6: Use the object picker to select the wingtiptoys.com\Accountants group and add it.
7: Back on the Security tab, select the Accountants group and click the check box Allowed to authenticate.
8: Repeat for other DCs in the domain.
9: From the Computers container, right-click Server1 and select its properties. From the Security tab, add the Accountants group and grant them the Allowed to authenticate permission.
10: Access the server file system
and grant the wingtiptoys\accounting group access as necessary.
So, there you have it. Simple, huh? No? Well, you know what they say
about practice…