How can I determine if the org that I'm currently connected to is a scratch org?Apex email extension points - How to replace Messaging.sendEmail or change it's behaviourHow can a Sandbox spin unwanted on a prerelease pod and how to undo it?Workaround for SELECT * (SELECT all) in sfdx force:data:tree:export SOQLCan .forceignore be used to not pull profiles that only exist in the scratch org?Salesforce DX: How to pre-populate scratch orgs with custom objects?Salesforcef DX: How to create a scratch org that opens in Classic by default?Where & how to find out what can be automized on SFDX scratch org creationError creating Scratch Org - The Streaming request failed to handshakeHow to delete Scratch Org user from deleted scratch?Scratch org: how to retrieve metadata

Why do UK politicians seemingly ignore opinion polls on Brexit?

Why is my log file so massive? 22gb. I am running log backups

Information to fellow intern about hiring?

Is there a way to make member function NOT callable from constructor?

Landlord wants to switch my lease to a "Land contract" to "get back at the city"

Could a US political party gain complete control over the government by removing checks & balances?

How to move the player while also allowing forces to affect it

How to create a consistant feel for character names in a fantasy setting?

Email Account under attack (really) - anything I can do?

Is a car considered movable or immovable property?

How is it possible for user's password to be changed after storage was encrypted? (on OS X, Android)

What does 'script /dev/null' do?

I see my dog run

What are the advantages and disadvantages of running one shots compared to campaigns?

Patience, young "Padovan"

How to deal with fear of taking dependencies

Shall I use personal or official e-mail account when registering to external websites for work purpose?

How can I fix this gap between bookcases I made?

extract characters between two commas?

When blogging recipes, how can I support both readers who want the narrative/journey and ones who want the printer-friendly recipe?

Latin words with no plurals in English

Wild Shape Centaur Into a Giant Elk: do their Charges stack?

Why doesn't a const reference extend the life of a temporary object passed via a function?

Can I find out the caloric content of bread by dehydrating it?



How can I determine if the org that I'm currently connected to is a scratch org?


Apex email extension points - How to replace Messaging.sendEmail or change it's behaviourHow can a Sandbox spin unwanted on a prerelease pod and how to undo it?Workaround for SELECT * (SELECT all) in sfdx force:data:tree:export SOQLCan .forceignore be used to not pull profiles that only exist in the scratch org?Salesforce DX: How to pre-populate scratch orgs with custom objects?Salesforcef DX: How to create a scratch org that opens in Classic by default?Where & how to find out what can be automized on SFDX scratch org creationError creating Scratch Org - The Streaming request failed to handshakeHow to delete Scratch Org user from deleted scratch?Scratch org: how to retrieve metadata






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








6















When I'm within a Salesforce org, how can I tell if that org is a Scratch Org or not?



Ideally this would be via Apex, but it could be an API call if required.



This would be useful information for the creator of a managed package who may not otherwise know what type of org is running the code.




I've had a couple of thoughts on how this might be achieved:



  1. Check if the pod/instance that Scratch orgs are created on are separate from the general population of sandbox orgs. I suspect that scratch orgs have dedicated hardware. E.g. a new scratch org I just created is on p0/CS31.

  2. Look for describe Metadata that is unique to only scratch orgs.









share|improve this question
























  • Full disclosure, this question has been discussed in the GoodDaySir slack channel. For posterity, it would be useful to have a solution listed in the open. gooddaysir.slack.com/messages/C3BJMEH3J/convo/…

    – Daniel Ballinger
    Apr 4 at 1:31












  • Can you see the relevant ActiveScratchOrg or ScratchOrgInfo from within one?

    – Adrian Larson
    Apr 4 at 1:33












  • @AdrianLarson Those are in the DevHub, aren't they? I don't think they would be reachable from the Scratch org itself in isolation.

    – Daniel Ballinger
    Apr 4 at 1:38











  • For scratch dev edition orgs in specific, they are always located on CS sandbox pods but also identify as Developer Edition. That's a combo you don't see anywhere other than scratch orgs at the moment.

    – Charles T
    Apr 4 at 4:54











  • One other option could be to query the Organization object and identify the difference between CreatedDate and TrialExpirationDate for an Org. In majority of the cases say for DE Orgs, Prod, and Sandboxes, TrialExpirationDate will be null. If you are not considering any trial orgs, then just having TrialExpirationDate populated will help identify that the org is a Scratch Org. For Scratch Orgs, the difference between the dates though will be anything between 1-30.

    – Jayant Das
    Apr 4 at 13:12


















6















When I'm within a Salesforce org, how can I tell if that org is a Scratch Org or not?



Ideally this would be via Apex, but it could be an API call if required.



This would be useful information for the creator of a managed package who may not otherwise know what type of org is running the code.




I've had a couple of thoughts on how this might be achieved:



  1. Check if the pod/instance that Scratch orgs are created on are separate from the general population of sandbox orgs. I suspect that scratch orgs have dedicated hardware. E.g. a new scratch org I just created is on p0/CS31.

  2. Look for describe Metadata that is unique to only scratch orgs.









share|improve this question
























  • Full disclosure, this question has been discussed in the GoodDaySir slack channel. For posterity, it would be useful to have a solution listed in the open. gooddaysir.slack.com/messages/C3BJMEH3J/convo/…

    – Daniel Ballinger
    Apr 4 at 1:31












  • Can you see the relevant ActiveScratchOrg or ScratchOrgInfo from within one?

    – Adrian Larson
    Apr 4 at 1:33












  • @AdrianLarson Those are in the DevHub, aren't they? I don't think they would be reachable from the Scratch org itself in isolation.

    – Daniel Ballinger
    Apr 4 at 1:38











  • For scratch dev edition orgs in specific, they are always located on CS sandbox pods but also identify as Developer Edition. That's a combo you don't see anywhere other than scratch orgs at the moment.

    – Charles T
    Apr 4 at 4:54











  • One other option could be to query the Organization object and identify the difference between CreatedDate and TrialExpirationDate for an Org. In majority of the cases say for DE Orgs, Prod, and Sandboxes, TrialExpirationDate will be null. If you are not considering any trial orgs, then just having TrialExpirationDate populated will help identify that the org is a Scratch Org. For Scratch Orgs, the difference between the dates though will be anything between 1-30.

    – Jayant Das
    Apr 4 at 13:12














6












6








6








When I'm within a Salesforce org, how can I tell if that org is a Scratch Org or not?



Ideally this would be via Apex, but it could be an API call if required.



This would be useful information for the creator of a managed package who may not otherwise know what type of org is running the code.




I've had a couple of thoughts on how this might be achieved:



  1. Check if the pod/instance that Scratch orgs are created on are separate from the general population of sandbox orgs. I suspect that scratch orgs have dedicated hardware. E.g. a new scratch org I just created is on p0/CS31.

  2. Look for describe Metadata that is unique to only scratch orgs.









share|improve this question
















When I'm within a Salesforce org, how can I tell if that org is a Scratch Org or not?



Ideally this would be via Apex, but it could be an API call if required.



This would be useful information for the creator of a managed package who may not otherwise know what type of org is running the code.




I've had a couple of thoughts on how this might be achieved:



  1. Check if the pod/instance that Scratch orgs are created on are separate from the general population of sandbox orgs. I suspect that scratch orgs have dedicated hardware. E.g. a new scratch org I just created is on p0/CS31.

  2. Look for describe Metadata that is unique to only scratch orgs.






apex scratch-org






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Apr 4 at 1:37







Daniel Ballinger

















asked Apr 4 at 1:16









Daniel BallingerDaniel Ballinger

74.3k15155406




74.3k15155406












  • Full disclosure, this question has been discussed in the GoodDaySir slack channel. For posterity, it would be useful to have a solution listed in the open. gooddaysir.slack.com/messages/C3BJMEH3J/convo/…

    – Daniel Ballinger
    Apr 4 at 1:31












  • Can you see the relevant ActiveScratchOrg or ScratchOrgInfo from within one?

    – Adrian Larson
    Apr 4 at 1:33












  • @AdrianLarson Those are in the DevHub, aren't they? I don't think they would be reachable from the Scratch org itself in isolation.

    – Daniel Ballinger
    Apr 4 at 1:38











  • For scratch dev edition orgs in specific, they are always located on CS sandbox pods but also identify as Developer Edition. That's a combo you don't see anywhere other than scratch orgs at the moment.

    – Charles T
    Apr 4 at 4:54











  • One other option could be to query the Organization object and identify the difference between CreatedDate and TrialExpirationDate for an Org. In majority of the cases say for DE Orgs, Prod, and Sandboxes, TrialExpirationDate will be null. If you are not considering any trial orgs, then just having TrialExpirationDate populated will help identify that the org is a Scratch Org. For Scratch Orgs, the difference between the dates though will be anything between 1-30.

    – Jayant Das
    Apr 4 at 13:12


















  • Full disclosure, this question has been discussed in the GoodDaySir slack channel. For posterity, it would be useful to have a solution listed in the open. gooddaysir.slack.com/messages/C3BJMEH3J/convo/…

    – Daniel Ballinger
    Apr 4 at 1:31












  • Can you see the relevant ActiveScratchOrg or ScratchOrgInfo from within one?

    – Adrian Larson
    Apr 4 at 1:33












  • @AdrianLarson Those are in the DevHub, aren't they? I don't think they would be reachable from the Scratch org itself in isolation.

    – Daniel Ballinger
    Apr 4 at 1:38











  • For scratch dev edition orgs in specific, they are always located on CS sandbox pods but also identify as Developer Edition. That's a combo you don't see anywhere other than scratch orgs at the moment.

    – Charles T
    Apr 4 at 4:54











  • One other option could be to query the Organization object and identify the difference between CreatedDate and TrialExpirationDate for an Org. In majority of the cases say for DE Orgs, Prod, and Sandboxes, TrialExpirationDate will be null. If you are not considering any trial orgs, then just having TrialExpirationDate populated will help identify that the org is a Scratch Org. For Scratch Orgs, the difference between the dates though will be anything between 1-30.

    – Jayant Das
    Apr 4 at 13:12

















Full disclosure, this question has been discussed in the GoodDaySir slack channel. For posterity, it would be useful to have a solution listed in the open. gooddaysir.slack.com/messages/C3BJMEH3J/convo/…

– Daniel Ballinger
Apr 4 at 1:31






Full disclosure, this question has been discussed in the GoodDaySir slack channel. For posterity, it would be useful to have a solution listed in the open. gooddaysir.slack.com/messages/C3BJMEH3J/convo/…

– Daniel Ballinger
Apr 4 at 1:31














Can you see the relevant ActiveScratchOrg or ScratchOrgInfo from within one?

– Adrian Larson
Apr 4 at 1:33






Can you see the relevant ActiveScratchOrg or ScratchOrgInfo from within one?

– Adrian Larson
Apr 4 at 1:33














@AdrianLarson Those are in the DevHub, aren't they? I don't think they would be reachable from the Scratch org itself in isolation.

– Daniel Ballinger
Apr 4 at 1:38





@AdrianLarson Those are in the DevHub, aren't they? I don't think they would be reachable from the Scratch org itself in isolation.

– Daniel Ballinger
Apr 4 at 1:38













For scratch dev edition orgs in specific, they are always located on CS sandbox pods but also identify as Developer Edition. That's a combo you don't see anywhere other than scratch orgs at the moment.

– Charles T
Apr 4 at 4:54





For scratch dev edition orgs in specific, they are always located on CS sandbox pods but also identify as Developer Edition. That's a combo you don't see anywhere other than scratch orgs at the moment.

– Charles T
Apr 4 at 4:54













One other option could be to query the Organization object and identify the difference between CreatedDate and TrialExpirationDate for an Org. In majority of the cases say for DE Orgs, Prod, and Sandboxes, TrialExpirationDate will be null. If you are not considering any trial orgs, then just having TrialExpirationDate populated will help identify that the org is a Scratch Org. For Scratch Orgs, the difference between the dates though will be anything between 1-30.

– Jayant Das
Apr 4 at 13:12






One other option could be to query the Organization object and identify the difference between CreatedDate and TrialExpirationDate for an Org. In majority of the cases say for DE Orgs, Prod, and Sandboxes, TrialExpirationDate will be null. If you are not considering any trial orgs, then just having TrialExpirationDate populated will help identify that the org is a Scratch Org. For Scratch Orgs, the difference between the dates though will be anything between 1-30.

– Jayant Das
Apr 4 at 13:12











2 Answers
2






active

oldest

votes


















8














The SourceMember sObject is only present in scratch orgs. Its presence would be a sign that you are in a scratch org. The gotcha would be that it is only accessible via the Tooling API and not Apex alone.



https://developer.salesforce.com/docs/atlas.en-us.api_tooling.meta/api_tooling/tooling_api_objects_sourcemember.htm






share|improve this answer























  • This seems like a great solution and shouldn't be too difficult with an HTTP request from Apex. Especially since we don't need the Remote Site setting anymore.

    – Daniel Ballinger
    Apr 4 at 1:40


















2














Using the Organization object, both scratch and trial orgs have TrialExpirationDate, but we can use IsSandbox to differentiate the two.



Organization org = [SELECT IsSandbox, TrialExpirationDate FROM Organization];
Boolean isScratchOrg = org.IsSandbox && org.TrialExpirationDate != null;
Boolean isTrialOrg = !org.IsSandbox && org.TrialExpirationDate != null;





share|improve this answer























    Your Answer








    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "459"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: false,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsalesforce.stackexchange.com%2fquestions%2f256499%2fhow-can-i-determine-if-the-org-that-im-currently-connected-to-is-a-scratch-org%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    2 Answers
    2






    active

    oldest

    votes








    2 Answers
    2






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    8














    The SourceMember sObject is only present in scratch orgs. Its presence would be a sign that you are in a scratch org. The gotcha would be that it is only accessible via the Tooling API and not Apex alone.



    https://developer.salesforce.com/docs/atlas.en-us.api_tooling.meta/api_tooling/tooling_api_objects_sourcemember.htm






    share|improve this answer























    • This seems like a great solution and shouldn't be too difficult with an HTTP request from Apex. Especially since we don't need the Remote Site setting anymore.

      – Daniel Ballinger
      Apr 4 at 1:40















    8














    The SourceMember sObject is only present in scratch orgs. Its presence would be a sign that you are in a scratch org. The gotcha would be that it is only accessible via the Tooling API and not Apex alone.



    https://developer.salesforce.com/docs/atlas.en-us.api_tooling.meta/api_tooling/tooling_api_objects_sourcemember.htm






    share|improve this answer























    • This seems like a great solution and shouldn't be too difficult with an HTTP request from Apex. Especially since we don't need the Remote Site setting anymore.

      – Daniel Ballinger
      Apr 4 at 1:40













    8












    8








    8







    The SourceMember sObject is only present in scratch orgs. Its presence would be a sign that you are in a scratch org. The gotcha would be that it is only accessible via the Tooling API and not Apex alone.



    https://developer.salesforce.com/docs/atlas.en-us.api_tooling.meta/api_tooling/tooling_api_objects_sourcemember.htm






    share|improve this answer













    The SourceMember sObject is only present in scratch orgs. Its presence would be a sign that you are in a scratch org. The gotcha would be that it is only accessible via the Tooling API and not Apex alone.



    https://developer.salesforce.com/docs/atlas.en-us.api_tooling.meta/api_tooling/tooling_api_objects_sourcemember.htm







    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered Apr 4 at 1:36









    HeberHeber

    19317




    19317












    • This seems like a great solution and shouldn't be too difficult with an HTTP request from Apex. Especially since we don't need the Remote Site setting anymore.

      – Daniel Ballinger
      Apr 4 at 1:40

















    • This seems like a great solution and shouldn't be too difficult with an HTTP request from Apex. Especially since we don't need the Remote Site setting anymore.

      – Daniel Ballinger
      Apr 4 at 1:40
















    This seems like a great solution and shouldn't be too difficult with an HTTP request from Apex. Especially since we don't need the Remote Site setting anymore.

    – Daniel Ballinger
    Apr 4 at 1:40





    This seems like a great solution and shouldn't be too difficult with an HTTP request from Apex. Especially since we don't need the Remote Site setting anymore.

    – Daniel Ballinger
    Apr 4 at 1:40













    2














    Using the Organization object, both scratch and trial orgs have TrialExpirationDate, but we can use IsSandbox to differentiate the two.



    Organization org = [SELECT IsSandbox, TrialExpirationDate FROM Organization];
    Boolean isScratchOrg = org.IsSandbox && org.TrialExpirationDate != null;
    Boolean isTrialOrg = !org.IsSandbox && org.TrialExpirationDate != null;





    share|improve this answer



























      2














      Using the Organization object, both scratch and trial orgs have TrialExpirationDate, but we can use IsSandbox to differentiate the two.



      Organization org = [SELECT IsSandbox, TrialExpirationDate FROM Organization];
      Boolean isScratchOrg = org.IsSandbox && org.TrialExpirationDate != null;
      Boolean isTrialOrg = !org.IsSandbox && org.TrialExpirationDate != null;





      share|improve this answer

























        2












        2








        2







        Using the Organization object, both scratch and trial orgs have TrialExpirationDate, but we can use IsSandbox to differentiate the two.



        Organization org = [SELECT IsSandbox, TrialExpirationDate FROM Organization];
        Boolean isScratchOrg = org.IsSandbox && org.TrialExpirationDate != null;
        Boolean isTrialOrg = !org.IsSandbox && org.TrialExpirationDate != null;





        share|improve this answer













        Using the Organization object, both scratch and trial orgs have TrialExpirationDate, but we can use IsSandbox to differentiate the two.



        Organization org = [SELECT IsSandbox, TrialExpirationDate FROM Organization];
        Boolean isScratchOrg = org.IsSandbox && org.TrialExpirationDate != null;
        Boolean isTrialOrg = !org.IsSandbox && org.TrialExpirationDate != null;






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Apr 4 at 16:19









        Kevin VizcarraKevin Vizcarra

        8815




        8815



























            draft saved

            draft discarded
















































            Thanks for contributing an answer to Salesforce Stack Exchange!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsalesforce.stackexchange.com%2fquestions%2f256499%2fhow-can-i-determine-if-the-org-that-im-currently-connected-to-is-a-scratch-org%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            រឿង រ៉ូមេអូ និង ហ្ស៊ុយលីយេ សង្ខេបរឿង តួអង្គ បញ្ជីណែនាំ

            Crop image to path created in TikZ? Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)Crop an inserted image?TikZ pictures does not appear in posterImage behind and beyond crop marks?Tikz picture as large as possible on A4 PageTransparency vs image compression dilemmaHow to crop background from image automatically?Image does not cropTikzexternal capturing crop marks when externalizing pgfplots?How to include image path that contains a dollar signCrop image with left size given

            Romeo and Juliet ContentsCharactersSynopsisSourcesDate and textThemes and motifsCriticism and interpretationLegacyScene by sceneSee alsoNotes and referencesSourcesExternal linksNavigation menu"Consumer Price Index (estimate) 1800–"10.2307/28710160037-3222287101610.1093/res/II.5.31910.2307/45967845967810.2307/2869925286992510.1525/jams.1982.35.3.03a00050"Dada Masilo: South African dancer who breaks the rules"10.1093/res/os-XV.57.1610.2307/28680942868094"Sweet Sorrow: Mann-Korman's Romeo and Juliet Closes Sept. 5 at MN's Ordway"the original10.2307/45957745957710.1017/CCOL0521570476.009"Ram Leela box office collections hit massive Rs 100 crore, pulverises prediction"Archived"Broadway Revival of Romeo and Juliet, Starring Orlando Bloom and Condola Rashad, Will Close Dec. 8"Archived10.1075/jhp.7.1.04hon"Wherefore art thou, Romeo? To make us laugh at Navy Pier"the original10.1093/gmo/9781561592630.article.O006772"Ram-leela Review Roundup: Critics Hail Film as Best Adaptation of Romeo and Juliet"Archived10.2307/31946310047-77293194631"Romeo and Juliet get Twitter treatment""Juliet's Nurse by Lois Leveen""Romeo and Juliet: Orlando Bloom's Broadway Debut Released in Theaters for Valentine's Day"Archived"Romeo and Juliet Has No Balcony"10.1093/gmo/9781561592630.article.O00778110.2307/2867423286742310.1076/enst.82.2.115.959510.1080/00138380601042675"A plague o' both your houses: error in GCSE exam paper forces apology""Juliet of the Five O'Clock Shadow, and Other Wonders"10.2307/33912430027-4321339124310.2307/28487440038-7134284874410.2307/29123140149-661129123144728341M"Weekender Guide: Shakespeare on The Drive""balcony"UK public library membership"romeo"UK public library membership10.1017/CCOL9780521844291"Post-Zionist Critique on Israel and the Palestinians Part III: Popular Culture"10.2307/25379071533-86140377-919X2537907"Capulets and Montagues: UK exam board admit mixing names up in Romeo and Juliet paper"Istoria Novellamente Ritrovata di Due Nobili Amanti2027/mdp.390150822329610820-750X"GCSE exam error: Board accidentally rewrites Shakespeare"10.2307/29176390149-66112917639"Exam board apologises after error in English GCSE paper which confused characters in Shakespeare's Romeo and Juliet""From Mariotto and Ganozza to Romeo and Guilietta: Metamorphoses of a Renaissance Tale"10.2307/37323537323510.2307/2867455286745510.2307/28678912867891"10 Questions for Taylor Swift"10.2307/28680922868092"Haymarket Theatre""The Zeffirelli Way: Revealing Talk by Florentine Director""Michael Smuin: 1938-2007 / Prolific dance director had showy career"The Life and Art of Edwin BoothRomeo and JulietRomeo and JulietRomeo and JulietRomeo and JulietEasy Read Romeo and JulietRomeo and Julieteeecb12003684p(data)4099369-3n8211610759dbe00d-a9e2-41a3-b2c1-977dd692899302814385X313670221313670221