-
Notifications
You must be signed in to change notification settings - Fork 13
OrgShape
STATUS: ACTIVE
Class contains static methods for determining if specific platform features are enabled. For example, do we have platform cache enabled. You could also write similar methods for experiences. Shared Code
Defines the default cache partition for use in this class.
TESTVISIBLE
TESTVISIBLE
returns this org's fiscal year starting month
reports whether this transaction took place in an org with a namespace prefix
reports the org's ID. in practice, this is a constant
returns the instance name. In practice not null.
reports the read-only status. this is a proxy for 'is this org active'
property reports whether this transaction took place in a sandbox.
reports the users' displayed theme.
reports the org's locale
reports whether or not this transaction took place in an org with multiCurrency enabled. Note: I have no idea why the underlying method is on UserInfo.
reports the org's name
reports the namespace prefix of this org. May return null;
reports this org's type. ie: 'Developer Edition'
convenience method. Alias for instanceName
reports the timeZoneSidKey
returns a Cache.Partition for a given name, and type
Param | Description |
---|---|
type |
Enum of .SESSION or .ORG |
Type | Description |
---|---|
Cache | Cache.Partition |
Method determines if platform cache is enabled for this org Note: fail-safes to false. Note: Allows override by setting OrgShape.disablePlatformCache equal to true. Use this in test contexts where cache is not available like when you have to use seeAllData=true
Type | Description |
---|---|
Boolean | Boolean |
Certain features of the platform are incompatible with data-siloed tests. These features require testing with the annotation
Type | Description |
---|---|
Boolean | Boolean |
Test (seeAllData=true). Other platform features are incompatible with seeAllData=true. When used in a test context, this method determines if the currently running test is executing with, or without seeAllData=true. This method is therefore used to automatically disable platform features that require are incompatible with seeAllData=true. For example: platform cache is incompatible with seeAllData=true. However, our security library, CanTheUser utilizes platform cache to accelerate Crud and FLS checks. CanTheUser uses this method, in part, to determine, transparently if it should utilize platformCache during test execution Note: It is not a good idea, and against best practices to use seeAllData=true when not absolutely necessary.
SUPPRESSWARNINGS
This method is responsible for discovering a cache partition that can be used for determining if platformCache is enabled and configured. Note: This method memoizes the result of the query, ensuring that the underlying soql query is only ever run once per transaction.
Type | Description |
---|---|
Cache | String |
Uses a dynamic soql query to determine if Advanced MultiCurrency Management is enabled. Note, this must be a dynamic soql query because referencing DatedConversionRate will not compile in orgs without Advanced MultiCurrency Management enabled. Note: This was originally written by the NPSP team and can be found here: https://github.com/SalesforceFoundation/NPSP/blob/aad20ffb747ecda9a037c4bce9cd19617b6a727b/src/classes/UTIL_Currency.cls#L79
Type | Description |
---|---|
Boolean | Boolean |
SUPPRESSWARNINGS
TESTVISIBLE
Private method that memoizes the query result Suppressing the PMD warning to validate crud permissions before DML, because the Organization Object is always available.
Type | Description |
---|---|
Organization | Organization |
SUPPRESSWARNINGS
Private method for pulling the Organization record Note: We're suppressing PMD warning on Crud Checking because we want everyone to be able to pull this read-only record.
Type | Description |
---|---|
Organization |
Organization Organization Record |
this class is used to marshall / return the cached org shape data, if available
Implemented types
SUPPRESSWARNINGS
We're suppressing PMD warning on Crud Checking because we want everyone to be able to pull this read-only record. Note this is a cachebuilder implementing class.
Param | Description |
---|---|
requiredButNotUsed |
String required by the interface, but not used in the method. It acts as the cache key, and since that's passed at runtime, it's used, but not by this method. |
Type | Description |
---|---|
Organization |
Organization Organization Record - hopefully from cache. |