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

- Share
 

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.的更多相关文章

  1. 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 ...

  2. 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 ...

  3. 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 ...

  4. 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 ...

  5. 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 ...

  6. 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 ...

  7. 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 ...

  8. 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 ...

  9. 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. ...

随机推荐

  1. 一位资深程序员大牛推荐的Java技术学习路线图

    Web应用,最常见的研发语言是Java和PHP. 后端服务,最常见的研发语言是Java和C/C++. 大数据,最常见的研发语言是Java和Python. 可以说,Java是现阶段中国互联网公司中,覆盖 ...

  2. iOS技术提升方向

    技术维度: 认知维度:

  3. [React技术内幕] setState的秘密

    对于大多数的React开发者,setState可能是最常用的API之一.React作为View层,通过改变data从而引发UI的更新.React不像Vue这种MVVM库,直接修改data并不能视图的改 ...

  4. 一篇文章彻底说清JS的深拷贝/浅拷贝

    一篇文章彻底说清JS的深拷贝and浅拷贝 这篇文章的受众 第一类,业务需要,急需知道如何深拷贝JS对象的开发者. 第二类,希望扎实JS基础,将来好去面试官前秀操作的好学者. 写给第一类读者 你只需要一 ...

  5. koa进阶史(二)

    之前想着放弃CAS的验证吧,但是又去请教了一个大牛,了解到sf公司的CAS验证校验的参数不是sessionId而是另外两个,后登陆sit环境偷了两个参数后,后台接口成功返回200.然后node层也就能 ...

  6. javascript入门进阶(一)

    javascript 入门进阶 这里主要讲解一下在入门阶段很难注意的一些知识点,不一定有用.但是会了总比不会强. 1.HTML为<script>标签准备的6个属性: -async:可选.表 ...

  7. 前后端分离项目采用Prerender的SEO优化流程

    原文: https://blog.ccyws.cn/articles/4 一.概述 近年开发模式变化,新建Web站点采用前后端分离部署已经是大势所趋.但是,搜索引擎爬虫不会执行js脚本从后端加载数据, ...

  8. 利用mnist数据集进行深度神经网络

    初始神经网络 这里要解决的问题是,将手写数字的灰度图像(28 像素 x28 像素)划分到 10 个类别中(0~9).我们将使用 MINST 数据集,它是机器学习领域的一个经典数据集,其历史几乎和这个领 ...

  9. Element UI中的上传文件功能

    上传文件给后台: <el-upload style="display:inline-block" :limit=" class="upload-demo& ...

  10. C++ 理解类 和 类中的public、protected、private

    我们要明确,不只是C++有类,很多语言也会用到类,因为现在很多都是面向对象编程... 在c++中,关于类的理解,个人理解是这样的,具有共同属性的一个集合被称为类, 比如说人这个集合,具有性别,年龄,出 ...