Building Applications with Force.com and VisualForce(Dev401)( 八):Designing Applications for Multiple Users: Controling Access to Records.
Module Objectives
1.List feature that affect access to data at the record level.
2.List the organization wide default(OWD) settings.
3.List and define the sharing levels.
4.Set Organization wide defaults.
5.Create a role.
6.Create a public group.
7.Create a sharing rule.
8.Manually share records.
Module Agenda
1.Overview of Record Access
2.Record Ownership
3.Organization Wide Defaults
4.Roles and "Groups" of Users
5.Sharing
Record Access
1.The sharing model determines access to specific records
- Who has access?
- What level of access?
- Why they have access?
2.Access to records is dependent on object CRUD.
Levels of Record Access
1.Full Access privileges:
- View
- Edit
- Transfer ownership
- Delete
Ways to Obtain Access to a Record
1.Full Access:
- Owner Field
. User
.Queue member
- Above user(who has ownership)in role hierarchy
- Profile permission:"Modify All Data"
2.Read/Write or Read Only access:
- Organization Wide Default
- Above user(who has read/write or read only access) in role hierarchy
- Manually sharing
- Sharing rules
- Apex sharing
- Profile permission: "View All Data"
Let's compare...Profiles & the Sharing Model
Profiles
1.Controls access to objects(Candidates, Positions,etc.)
2.Cotrols access to fields(Candidate Name, Min pay, Skill required,etc.)
Sharing Model
1.Controls access to records(ex:one candidate,Joe Schmoe,one position,Black Box tester)
So, a User'profile might specify that a user can see candidates, but the sharing model determines which candidates that user can see.
The sharing model might determine that a user can see Joe Schmoe, But the profile specifies which field that user can view and edit.
Record Ownership
1.Most Records have an associated Owner
-Exception:child records in a master-detail relationship inherit access rights from parent record
2.Types of Owners
- Users
- Queues
- Record owners have Full Access
Universal Containers Scenario
1.At Universal Containers, Al employees are allowed to view open potions.
2.There will never be any position that an employee is not permitted to see.
3.Hiring managers should be able to update and view all fields only for positions where they are the hiring manager.
4.Recruiters should be able to view and update all positions that they own.
5.Interviews should only be able to view candidates and job applications to which they have been assigned.
6.Interviews should be able to create and edit their own reviews, but they shouldn't be able to read reviews of others.
7.Universal Containers needs to set organization wide defaults for the objects in its Recruiting Application to satisfy these requirements.
What are Organization Wide Defaults (OWD)?
1.Organization Wide defaults are a security setting that defines the baseline level of access to data records that you do not own.
2.They are the only way to restrict access to data in the sharing model.
3.They can be defined for the custom as well as several standard objects.
4.Access levels:
- Public Read/Write(all users can see and edit every record)
- Public Read Only (all users can see every record)
- Private (users can only see records that they own)
Determining How to Set OWD for an object
Questions to ask:
1.Who is the most restricted user of this object?
2.Is there ever going to be an instance of this object that his user shouldn't be allowed to see?
3.Is there ever going to be an instance of this object that this user shouldn't be allowed to edit?
Organization Wide defaults considerations
1.Child records in master-detail relationships inherit their organization wide defaults from their parents.
2.Child records in look-up relations have independent organization wide defaults from their parents.
3.Changing organization wide defaults can produce unintended consequence consider your business requirements carefully before setting your organization wide defaults.
4.Change organization wide defaults can potentially delete manual sharing if that sharing is no longer needed,
- For example, change from Private to Public Read/Write.
Review
1.True or False:Child records in master detail relationships have their own organization wide defaults.
False
2.What is the most restrictive level of access that can be set on organization wide defaults?
Private.
3.True of False:Organization wide defaults can be set for both standard and custom objects.
True.
4.IF even one person in your organization is not allowed to see position data, whant must you OWD be?
Private.
Universal Containers Scenario
1. Universal Containers' role hierarchy:
What are Roles and Role Hierarchy?
1.A Role:
- Controls the level of visibility that users have to an organization's data.
- A user may be associated to one role.
2 The Role Hierarchy:
- Controls data visibility.
- Controls record roll up for reporting
- Users usually inherit the special privileges of data owned
- Not necessarily the company's organization chart.
Role Hierarchy Considerations
1.With Standard Objects, access to records rolls up through the Role Hierarchy.
2.With Custom Objects, developers choose whether or not access should roll up through the role hierarchy.
- Determined by the Grand Access using Hierarchies setting on organization wide defaults.
Knowledge Check
Assuming organization wide defaults are set to Private and Grand Access Using Hierarchies is checked:
1.What can Cynthia Capobianco see?
2.Can Andrew Golbberg see records owned by Amy Lojack?can he edit them?
3.Can Megan Smith edit records owned by mario Ruiz?
Public Groups
1.Public groups are a way of grouping together users for access.
- Can be used in s sharing rule.
- Can be used to give access to folders.
2.Every organization has a default public group:Entire Organization
3.Public Groups can be mad up of any conbination of
- Users
- Roles
- Roles and Subordinates
- Public Groups
4.When public group are and up of roles or roles and subordinates, when a user is added or removed from the role,public group membership is updated.
Universal Containers Scenario
1.Megan Smith's team cannot see any reviews owned by Andrew Goldberg's Team
2.Ben Stuart cannot see reviews written by QA or Product Management
3.Melissa Lee cannot see records for candidates she needs to interview
Sharing Rules and Manual Sharing
1.Sharing Rules:
- Automatic exceptions to organization wide defaults for particular groups of users.
- used to open access to records.
- Never permitted to be more strict than organization wide default settings.
2.Manaul Sharing:
- used to open up access to records on a one-off basic when it is too difficult to come up with a consistent set of users who need access.
- Granted by owners, anyone above owners in the role hierarchy, and system Administrators.
Apex Sharing Reasons
1.Click the Sharing button on a record displays the various reasons that a user might have access to a record. Example of sharing reasons include:
- Administrator
- Owner
- Custom Object Sharing Rule
2.Establishing Apex sharing reasons allows developers to define the reason that a user or group of users might have access to a record.
Building Applications with Force.com and VisualForce(Dev401)( 八):Designing Applications for Multiple Users: Controling Access to Records.的更多相关文章
- Building Applications with Force.com and VisualForce(Dev401)( 八):Designing Applications for Multiple users:Managing your users' experience II
Dev 401-008: Design Applications for Multiple Users' Experience Part 2Universal Containers Scenario1 ...
- Building Applications with Force.com and VisualForce(Dev401)(七):Designing Applications for Multiple users:Managing your users' experience I
Dev 401-007 Designing Applications for Multiple users: Managing your users' experience part 1 Module ...
- Building Applications with Force.com and VisualForce(Dev401)(十):Designing Applications for Multiple Users: Building Business Processes that You Want
Dev401-011: Building Business Processes that You Want Course Objectives1.Describe the capabilities o ...
- Building Applications with Force.com and VisualForce(Dev401)(十一):Designing Applications for Multiple Users: Proseving Data Quality
Dev401-012:Proseving Data Quality Universal Containers Scenario1.Universal Containers(UC) wants to e ...
- Building Applications with Force.com and VisualForce(Dev401)( 九):Designing Applications for Multiple Users: Putting It All Together
Module Objectives1.Apply profiles, organization wide defaults, role hierarchy and sharing to given a ...
- Building Applications with Force.com and VisualForce(六):Designing Applications for Multiple users: Accommodating Multiple Users in your App
Dev 401-006 Designing Applications for Multiple users: Accommodating Multiple Users in your App. Cou ...
- Building Applications with Force.com and VisualForce (DEV401) (二) : Application Essentials:Designing Application on the Force.com Platform
Dev 401-002:Application Essentials:Designing Application on the Force.com Platform Course Objectives ...
- Building Applications with Force.com and VisualForce(Dev401)(十八):Visualforce Pages: Introduction to Visualforce
Dev401-020:Visualforce Pages: Introduction to Visualforce Course Objectives1.Understand the benefits ...
- Building Applications with Force.com and VisualForce (DEV401) (四):Building Your user Interface
Dev 401-004:Application essential:Building Your user Interface: Module Agenda1.Custom Applications2. ...
随机推荐
- OAuth 流程与发展总结 (1.0 => 1.0a => 2.0)
OAuth 流程与发展 (1.0 => 1.0a => 2.0) 概述 概述: 开放授权协议 作用: 允许第三方应用访问服务提供方中注册的终端用户的部分资源 下面是官方描述: [OAuth ...
- [LeetCode] 面试题 10.01.合并排序的数组
题目: 这道题有多种实现的思路,这里使用双指针结合数组有序的特点进行解决 思路: m代表A初始时有效元素的个数,n代表B中元素的个数,那么n+m才是A的总长度 从A的最后一个位置开始,设为cur,分别 ...
- .Net Core 为 x86 和 x64 程序集编写 AnyCPU 包装
前言 这几天研究了一下 vJoy 这个虚拟游戏手柄驱动,感觉挺好玩的.但是使用时发现一个问题,C# SDK 中的程序集被分为 x86 和 x64 两个版本,如果直接在 AnyCPU 平台编译运行就有隐 ...
- linux 读取 USB HID鼠标坐标和点击 在 LCD上显示
首先要,编译内核时启用了 USB HID 设备.启用了 鼠标 . 在开发板上插入usb 时会有如下提示. 可以看到,多了一个 mouse0 和 eventX 打出来的是我的 联想鼠标. 1, 在 终端 ...
- 【工具】---- webpack简析
1. 什么是webpack 一个现代 JavaScript 应用程序的静态模块打包器(module bundler),它会分析你的项目结构,找到JavaScript模块以及其它的一些浏览器不能直接运行 ...
- Django中update和save()同时作用
数据更新操作,对单条记录,可以使用save或者是update两种方式. save() 默认保存后会看到sql语句中更新了所有字段,而save的值是之前获取时候的字段值,是缓存下来的,并不一定最新,可能 ...
- Vue2.0 【第一季】第7节 v-bind指令
目录 Vue2.0 [第一季] 第7节 v-bind指令 第7节 v-bind指令 v-bind缩写 绑定CSS样式 Vue2.0 [第一季] 第7节 v-bind指令 第7节 v-bind指令 v- ...
- 6.前台项目vue环境、创建、目录重构、CSS、JS配置
目录 前台 vue环境 创建项目 重构项目目录 文件修订:目录中非配置文件的多余文件可以移除 App.vue router/index.js Home.vue 全局配置:全局样式.配置文件 globa ...
- Linux内核文档:如何写符合 kernel-doc 规范的注释
简介 Linux内核使用 Sphinx 实现把 Documentation 目录下的 reStructuredText 文件转换为非常漂亮的文档.文档既可以通过 make htmldocs 转换成 H ...
- Java第一节课考试
1 package kaoshi; import java.util.Scanner; public class ScoreInformation { Scanner input=new Scanne ...