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. ...
随机推荐
- 下一代网际协议IPv6
下一代网际协议IPv6 一.解决 IP 地址耗尽的措施 从计算机本身发展以及从因特网规模和网络传输速率来看,现在 IPv4 已很不适用. 最主要的问题就是 32 位的 IP 地址不够用. 在 2019 ...
- JavaScript 预解析机制
首先我们来看一段代码: <script> console.log(a); var a = 10; </script> 此时运行结果为 为什么会显示undefined呢?这就 ...
- 关于HTTP那些事
写这篇文章的原因 记录前端性能优化用到的关键概念 简化大家对HTTP的学习 大家或许面试的时候可以用得到哦 HTTP是什么 Web的应用层协议(超文本传输协议HyperText Transfer Pr ...
- 手机浏览器自动播放视频video(设置autoplay无效)的解决方案
1.问题的提出 某一天接了个需求,需要在手机的H5页面内加入视频,我开开心心做完,准备交付的时候,问题来了,PM想要用户一进入页面,视频就开始播放,不需要用户手动点击. 2.尝试解决 加autopla ...
- vue之initComputed模块源码说明
要想理解原理就得看源码,最近网上也找了好多vue初始化方法(8个init恶魔...) 因为也是循序渐进的理解,对initComputed计算属性的初始化有几处看得不是很明白,网上也都是含糊其辞的(要想 ...
- 在浏览器中使用ES6的模块功能 import 及 export
感谢英文原作者 Jake Archibald 的技术分享 各个浏览器对于ES6模块 import . export的支持情况 Safari 10.1. Chrome 61. Firefox 54 – ...
- Git将文件上传至Github过程
1.安装Git工具(在这里就不多说了) 2.我们需要先创建一个本地的版本库(其实也就是一个文件夹). 你可以直接在桌面右击新建文件夹,也可以右击打开Git bash命令行窗口通过命令来创建. 现在我通 ...
- 整合Kafka+Flink 实例(第二部分 设计思路)
前 言 拖了蛮久了,一直说要接着上一部分写设计思路以及代码,因为自己技术底子薄弱,加上人又懒,所以一直没能继续,今天补上设计思路及部分代码,后面有时间我会再补充一些应用性的功能,的确有些忙,希 ...
- python学习-练习题1巩固(随机数)
1.生成随机数 random.random()生成一个0-1之前的随机数
- 一文深入了解史上最强的Java堆内缓存框架Caffeine
它提供了一个近乎最佳的命中率.从性能上秒杀其他一堆进程内缓存框架,Spring5更是为了它放弃了使用多年的GuavaCache 缓存,在我们的日常开发中用的非常多,是我们应对各种性能问题支持高并发的一 ...