전자 메일 가능한 엔터티 만들기 및 업데이트
게시 날짜: 2017년 1월
적용 대상: Dynamics 365 (online), Dynamics 365 (on-premises), Dynamics CRM 2016, Dynamics CRM Online
해당 엔터티에 대한 레코드에 전자 메일 활동을 보내는 데 사용할 수 있는 전자 메일 주소가 포함된 엔터티를 만들 수 있습니다.
다음 샘플에서는 사용자 지정 엔터티를 만들고 IsActivityParty 속성을 true로 설정합니다. 사용할 전자 메일 주소를 제공하는 StringFormatName.Email을 사용하여 StringAttributeMetadata 특성도 만듭니다.
서식이 지정된 다른 StringAttributeMetadata 특성을 전자 메일 주소로 추가하더라도 첫 번째 특성만 사용됩니다.
// Create the custom entity.
CreateEntityRequest createrequest = new CreateEntityRequest
{
// Define an entity to enable for emailing. In order to do so,
// IsActivityParty must be set.
Entity = new EntityMetadata
{
SchemaName = _customEntityName,
DisplayName = new Label("Agent", 1033),
DisplayCollectionName = new Label("Agents", 1033),
Description = new Label("Insurance Agents", 1033),
OwnershipType = OwnershipTypes.UserOwned,
IsActivity = false,
// Unless this flag is set, this entity cannot be party to an
// activity.
IsActivityParty = true
},
// As with built-in emailable entities, the Primary Attribute will
// be used in the activity party screens. Be sure to choose descriptive
// attributes.
PrimaryAttribute = new StringAttributeMetadata
{
SchemaName = "new_fullname",
RequiredLevel = new AttributeRequiredLevelManagedProperty(AttributeRequiredLevel.None),
MaxLength = 100,
FormatName = StringFormatName.Text,
DisplayName = new Label("Agent Name", 1033),
Description = new Label("Agent Name", 1033)
}
};
_serviceProxy.Execute(createrequest);
Console.WriteLine("The emailable entity has been created.");
// The entity will not be selectable as an activity party until its customizations
// have been published. Otherwise, the e-mail activity dialog cannot find
// a correct default view.
PublishAllXmlRequest publishRequest = new PublishAllXmlRequest();
_serviceProxy.Execute(publishRequest);
// Before any emails can be created for this entity, an Email attribute
// must be defined.
CreateAttributeRequest createFirstEmailAttributeRequest = new CreateAttributeRequest
{
EntityName = _customEntityName,
Attribute = new StringAttributeMetadata
{
SchemaName = "new_emailaddress",
RequiredLevel = new AttributeRequiredLevelManagedProperty(AttributeRequiredLevel.None),
MaxLength = 100,
FormatName = StringFormatName.Email,
DisplayName = new Label("Email Address", 1033),
Description = new Label("Email Address", 1033)
}
};
_serviceProxy.Execute(createFirstEmailAttributeRequest);
Console.WriteLine("An email attribute has been added to the emailable entity.");
// Create a second, alternate email address. Since there is already one
// email attribute on the entity, this will never be used for emailing
// even if the first one is not populated.
CreateAttributeRequest createSecondEmailAttributeRequest = new CreateAttributeRequest
{
EntityName = _customEntityName,
Attribute = new StringAttributeMetadata
{
SchemaName = "new_secondaryaddress",
RequiredLevel = new AttributeRequiredLevelManagedProperty(AttributeRequiredLevel.None),
MaxLength = 100,
FormatName = StringFormatName.Email,
DisplayName = new Label("Secondary Email Address", 1033),
Description = new Label("Secondary Email Address", 1033)
}
};
_serviceProxy.Execute(createSecondEmailAttributeRequest);
Console.WriteLine("A second email attribute has been added to the emailable entity.");
' Create the custom entity.
Dim createrequest As CreateEntityRequest = New CreateEntityRequest With {.Entity = New EntityMetadata With {
.SchemaName = _customEntityName,
.DisplayName = New Label("Agent", 1033),
.DisplayCollectionName = New Label("Agents", 1033),
.Description = New Label("Insurance Agents", 1033),
.OwnershipType = OwnershipTypes.UserOwned,
.IsActivity = False, .IsActivityParty = True},
.PrimaryAttribute = New StringAttributeMetadata With {
.SchemaName = "new_fullname",
.RequiredLevel = New AttributeRequiredLevelManagedProperty(AttributeRequiredLevel.None),
.MaxLength = 100,
.Format = StringFormat.Text,
.DisplayName = New Label("Agent Name", 1033),
.Description = New Label("Agent Name", 1033)
}
}
' Define an entity to enable for emailing. In order to do so,
' IsActivityParty must be set.
' Unless this flag is set, this entity cannot be party to an
' activity.
' As with built-in emailable entities, the Primary Attribute will
' be used in the activity party screens. Be sure to choose descriptive
' attributes.
_serviceProxy.Execute(createrequest)
Console.WriteLine("The emailable entity has been created.")
' The entity will not be selectable as an activity party until its customizations
' have been published. Otherwise, the e-mail activity dialog cannot find
' a correct default view.
Dim publishRequest As New PublishAllXmlRequest()
_serviceProxy.Execute(publishRequest)
' Before any emails can be created for this entity, an Email attribute
' must be defined.
Dim createFirstEmailAttributeRequest As CreateAttributeRequest = New CreateAttributeRequest With {
.EntityName = _customEntityName,
.Attribute = New StringAttributeMetadata With {
.SchemaName = "new_emailaddress",
.RequiredLevel = New AttributeRequiredLevelManagedProperty(AttributeRequiredLevel.None),
.MaxLength = 100,
.Format = StringFormat.Email,
.DisplayName = New Label("Email Address", 1033),
.Description = New Label("Email Address", 1033)
}
}
_serviceProxy.Execute(createFirstEmailAttributeRequest)
Console.WriteLine("An email attribute has been added to the emailable entity.")
' Create a second, alternate email address. Since there is already one
' email attribute on the entity, this will never be used for emailing
' even if the first one is not populated.
Dim createSecondEmailAttributeRequest As CreateAttributeRequest = New CreateAttributeRequest With {
.EntityName = _customEntityName,
.Attribute = New StringAttributeMetadata With {
.SchemaName = "new_secondaryaddress",
.RequiredLevel = New AttributeRequiredLevelManagedProperty(AttributeRequiredLevel.None),
.MaxLength = 100,
.Format = StringFormat.Email,
.DisplayName = New Label("Secondary Email Address", 1033),
.Description = New Label("Secondary Email Address", 1033)
}
}
_serviceProxy.Execute(createSecondEmailAttributeRequest)
Console.WriteLine("A second email attribute has been added to the emailable entity.")
참고 항목
샘플 및 도우미 코드 사용
Customize 엔터티 메타데이터
사용자 지정 가능한 엔터티는 무엇입니까?
사용자 지정 엔터티 만들기
엔터티 검색, 업데이트 및 삭제
사용자 지정 활동 엔터티 만들기
엔터티의 아이콘 수정
엔터티의 메시지 수정
샘플: 전자 메일 가능한 엔터티 만들기 및 업데이트
Microsoft Dynamics 365
© 2017 Microsoft. All rights reserved. 저작권 정보