>  기사  >  백엔드 개발  >  WordPress에서 기본 CRM 구축: 사용자 정의 기능 활용

WordPress에서 기본 CRM 구축: 사용자 정의 기능 활용

WBOY
WBOY원래의
2023-08-29 20:01:01961검색

WordPress에서 간단한 CRM 시스템을 만드는 방법을 살펴보았습니다. 이 시리즈의 마지막 부분에서는 역할을 사용하여 WordPress 관리 인터페이스의 일부에 대한 사용자 액세스를 제한하는 방법을 살펴보았습니다.

오늘은 사용자 정의 기능을 사용하여 연락처의 사용자 정의 게시물 유형에만 액세스를 제한하는 방법을 다루겠습니다.

맞춤 기능

이전에는 WordPress 사용자의 액세스 수준을 낮추었지만 사용자는 여전히 게시물과 댓글을 편집자 또는 작성자 역할에 할당하여 관리할 수 있습니다. 이러한 기능은 우리에게 유용하지 않으므로 액세스를 추가로 제한하고 특정 사용자가 연락처 사용자 정의 게시물 유형에만 액세스하도록 허용해야 합니다.

이를 수행할 수 있는 방법:

  1. 맞춤 게시물 유형에 맞춤 기능을 등록하세요
  2. 새 WordPress 사용자 역할을 생성하고 해당 역할에 새로운 사용자 정의 기능만 할당하세요
  3. WordPress 사용자를 생성/편집하고 새 연락처 역할에 할당

맞춤 게시물 유형에 맞춤 기능을 등록하세요

사용자 정의 기능을 등록하면 나중에 작성자가 새 연락처를 만들 수 있는지 여부와 같이 해당 기능에 액세스할 수 있는 WordPress 역할을 정의할 수 있습니다.

플러그인 파일을 편집하고 register_post_type() 函数调用,将 capability_type => 'post'를 다음으로 바꾸겠습니다.

으아아아

우리의 register_post_type() 함수는 이제 다음과 같아야 합니다:

으아아아

여기서 두 가지 일이 발생합니다:

  1. 연락처 사용자 정의 게시물 유형에서 작동한다는 점을 제외하면 동일한 기능에 capability 参数定义了自己的功能,并将它们映射到其 Post 等效项。这可确保 WordPress 准确理解这些功能的含义(即 edit_contact 的行为方式与 edit_post를 사용합니다.
  2. 우리는 WordPress에 map_meta_cap를 사용하여 시행 목적으로 위 기능을 WordPress의 기본 기능에 매핑하도록 지시했습니다.

모든 사용자로 WordPress 관리자를 다시 로드하면 WordPress 관리자 메뉴에서 연락처 사용자 정의 게시물 유형이 사라진 것을 확인할 수 있습니다.

在 WordPress 中构建基本 CRM:利用自定义功能

이제 WordPress에 새로운 연락처 기능(edit_contactedit_contacts 등)이 있는 역할을 알려야 하기 때문에 이런 일이 발생합니다.

새로운 WordPress 사용자 역할을 생성하고 새로운 사용자 정의 기능을 할당하세요

add_role()을 사용하여 새로운 WordPress 사용자 역할을 생성하고 여기에 연락처 기능을 할당할 수 있습니다. 역할은 WordPress 옵션 데이터에 저장되므로 해당 함수를 한 번만 호출하면 됩니다.

이렇게 하려면 플러그인의 __construct() 함수 끝에 다음 함수를 추가하세요.

으아아아

이 기능은 CRM이라는 새로운 역할을 WordPress에 추가합니다. 이 역할에 할당된 사용자는 연락처 기능에만 액세스할 수 있습니다. 따라서 연락처 사용자 정의 게시물 유형에만 액세스할 수 있습니다.

우리는 이 역할에 read 기능도 할당했습니다. 이는 사용자가 자신의 프로필(이름, 비밀번호 등)을 편집할 수 있도록 허용하는 데 필요합니다. 사용자가 로그인하면 WordPress가 자동으로 사용자를 프로필 화면으로 리디렉션하므로 이 작업을 허용해야 합니다.

read 기능을 할당하지 않으면 사용자가 로그인할 때 다음과 같은 일이 발생합니다.

在 WordPress 中构建基本 CRM:利用自定义功能

plugin_activation() 함수를 한 번 실행하려면 플러그인 파일 끝에 다음 코드를 추가합니다.

으아아아

이것은 WordPress에 플러그인을 활성화할 때 WPTutsCRM 클래스에서 WPTutsCRM 类中的 plugin_activation() 함수를 호출해야 함을 알려줍니다.

WordPress 사용자를 생성/편집하고 새 연락처 역할에 할당

다음으로, 플러그인을 비활성화했다가 다시 활성화하고 WordPress 관리 인터페이스에서 사용자 > 새로 추가 로 이동하세요.

모든 것이 순조롭게 진행되면 드롭다운 목록에 새로운 CRM 역할이 표시됩니다.

在 WordPress 中构建基本 CRM:利用自定义功能

계속해서 crm이라는 새 사용자를 만들고 해당 새 사용자로 로그인해 보겠습니다. 이제 연락처 가 표시되며 대시보드 프로필 이 유일한 다른 메뉴 옵션입니다.

在 WordPress 中构建基本 CRM:利用自定义功能

为其他角色分配自定义功能

如果我们注销并以 WordPress 管理员、编辑或作者身份重新登录,您会发现 WordPress 管理菜单中仍然缺少联系人自定义帖子类型:

在 WordPress 中构建基本 CRM:利用自定义功能

这个是因为我们只分配了 CRM 角色我们的联系人自定义帖子类型的功能。因此,所有其他用户角色仍然无权访问此帖子类型。

To fix this, let’s assign the Custom Capabilities to the Administrator and Editor Roles by adding the following code to the end of the plugin_activation() function:

// Add custom capabilities to Admin and Editor Roles
$roles = array( 'administrator', 'editor' );
foreach ( $roles as $roleName ) {
	// Get role
	$role = get_role( $roleName );
	
	// Check role exists
	if ( is_null( $role) ) {
		continue;
	}
	
	// Iterate through our custom capabilities, adding them
	// to this role if they are enabled
	foreach ( $customCaps as $capability => $enabled ) {
		if ( $enabled ) {
			// Add capability
			$role->add_cap( $capability );
		}
	}
}

在这里,我们迭代要为其分配自定义功能的角色,检查该角色是否存在。如果是,我们就会迭代之前定义的自定义功能,将它们添加到角色中。

您会注意到我们没有向作者角色添加任何自定义功能;这是因为我们不想分配所有功能,因为作者角色传统上只允许对该用户自己的帖子进行写入访问。

让我们通过为作者角色添加一些功能来继续构建我们的 plugin_activation() 函数:

// Add some of our custom capabilities to the Author Role
$role = get_role( 'author' );
$role->add_cap( 'edit_contact' );
$role->add_cap( 'edit_contacts' );
$role->add_cap( 'publish_contacts' );
$role->add_cap( 'read_contact' );
$role->add_cap( 'delete_contact' );
unset( $role );

我们的整个函数现在应该如下所示:

/**
* Activation hook to register a new Role and assign it our Contact Capabilities
*/
function plugin_activation() {
	
	// Define our custom capabilities
	$customCaps = array(
		'edit_others_contacts'			=> true,
		'delete_others_contacts'		=> true,
		'delete_private_contacts'		=> true,
		'edit_private_contacts'			=> true,
		'read_private_contacts'			=> true,
		'edit_published_contacts'		=> true,
		'publish_contacts'				=> true,
		'delete_published_contacts'		=> true,
		'edit_contacts'					=> true,
		'delete_contacts'				=> true,
		'edit_contact'					=> true,
		'read_contact'					=> true,
		'delete_contact'				=> true,
		'read'							=> true,
	);
	
	// Create our CRM role and assign the custom capabilities to it
	add_role( 'crm', __( 'CRM', 'tuts-crm'), $customCaps );
	
	// Add custom capabilities to Admin and Editor Roles
	$roles = array( 'administrator', 'editor' );
	foreach ( $roles as $roleName ) {
		// Get role
		$role = get_role( $roleName );
		
		// Check role exists
		if ( is_null( $role) ) {
			continue;
		}
		
		// Iterate through our custom capabilities, adding them
		// to this role if they are enabled
		foreach ( $customCaps as $capability => $enabled ) {
			if ( $enabled ) {
				// Add capability
				$role->add_cap( $capability );
			}
		}
	}
			
	// Add some of our custom capabilities to the Author Role
	$role = get_role( 'author' );
	$role->add_cap( 'edit_contact' );
	$role->add_cap( 'edit_contacts' );
	$role->add_cap( 'publish_contacts' );
	$role->add_cap( 'read_contact' );
	$role->add_cap( 'delete_contact' );
	unset( $role );
	
}

以管理员、编辑或作者身份登录现在将在 WordPress 管理菜单中显示“联系人”选项:

在 WordPress 中构建基本 CRM:利用自定义功能

清洁提升我们的角色

如果 WordPress 管理员停用我们的插件,CRM 角色将保留在 WordPress 中。但是,鉴于没有其他插件或 WordPress 的一部分使用此角色,因此它是多余的 - 因此我们需要确保在停用我们的插件时删除 CRM 角色。

为此,请在 plugin_activation() 函数下方添加以下函数:

/**
* Deactivation hook to unregister our existing Contacts Role
*/
function plugin_deactivation() {
	
	remove_role( 'crm' );
	
}

与我们在插件激活时使用 register_activation_hook() 函数的方式相同,当我们的插件停用时,我们可以使用 register_deactivation_hook() 函数。让我们在 register_activation_hook 调用下面添加以下内容:

register_deactivation_hook( __FILE__, array( &$wpTutsCRM, 'plugin_deactivation' ) );

停用我们的插件后,我们的 CRM 角色将不再可用。

摘要

我们已经在 WordPress 中成功创建了一个简单的 CRM 系统,探索使用自定义帖子类型、帖子元字段和第三方插件集成来存储有关我们的客户和潜在客户的信息。

本教程还涵盖了 WordPress 的一些更高级的方面,包括通过 WP_List_Table 列显示高级自定义字段数据、过滤我们的帖子查询以搜索我们的高级自定义字段数据,以及通过角色和功能管理用户访问以限制访问仅限我们的 CRM 系统。

위 내용은 WordPress에서 기본 CRM 구축: 사용자 정의 기능 활용의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.