Is it insecure to make Perl's prove command NOPASSWD in sudoers file?

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP











up vote
0
down vote

favorite












I've got a Perl test script, initiated with prove, that tests a backup script that requires root privileges so rsync can change the permissions on the files it downloaded from a remote server.



So I've got the following in my Mac's sudoers file:



root ALL=(ALL) ALL
%admin ALL=(ALL) ALL
%admin ALL=(ALL) NOPASSWD:/path/to/prove


It works. But my question is, since prove can be used to run pretty much any perl script written by the local user, is this a huge security risk?







share|improve this question
















  • 2




    It' yes, because anyone can write a Perl script to run any command as root. Just don't do it.
    – cuonglm
    Jan 23 at 2:58










  • this is no different to allowing perl or awk or bash or any other script interpreter to be run as root....and, as they can run other programs, it's equivalent to allowing ANY program to be run as root with any args.
    – cas
    Jan 23 at 4:33














up vote
0
down vote

favorite












I've got a Perl test script, initiated with prove, that tests a backup script that requires root privileges so rsync can change the permissions on the files it downloaded from a remote server.



So I've got the following in my Mac's sudoers file:



root ALL=(ALL) ALL
%admin ALL=(ALL) ALL
%admin ALL=(ALL) NOPASSWD:/path/to/prove


It works. But my question is, since prove can be used to run pretty much any perl script written by the local user, is this a huge security risk?







share|improve this question
















  • 2




    It' yes, because anyone can write a Perl script to run any command as root. Just don't do it.
    – cuonglm
    Jan 23 at 2:58










  • this is no different to allowing perl or awk or bash or any other script interpreter to be run as root....and, as they can run other programs, it's equivalent to allowing ANY program to be run as root with any args.
    – cas
    Jan 23 at 4:33












up vote
0
down vote

favorite









up vote
0
down vote

favorite











I've got a Perl test script, initiated with prove, that tests a backup script that requires root privileges so rsync can change the permissions on the files it downloaded from a remote server.



So I've got the following in my Mac's sudoers file:



root ALL=(ALL) ALL
%admin ALL=(ALL) ALL
%admin ALL=(ALL) NOPASSWD:/path/to/prove


It works. But my question is, since prove can be used to run pretty much any perl script written by the local user, is this a huge security risk?







share|improve this question












I've got a Perl test script, initiated with prove, that tests a backup script that requires root privileges so rsync can change the permissions on the files it downloaded from a remote server.



So I've got the following in my Mac's sudoers file:



root ALL=(ALL) ALL
%admin ALL=(ALL) ALL
%admin ALL=(ALL) NOPASSWD:/path/to/prove


It works. But my question is, since prove can be used to run pretty much any perl script written by the local user, is this a huge security risk?









share|improve this question











share|improve this question




share|improve this question










asked Jan 23 at 2:43









StevieD

1507




1507







  • 2




    It' yes, because anyone can write a Perl script to run any command as root. Just don't do it.
    – cuonglm
    Jan 23 at 2:58










  • this is no different to allowing perl or awk or bash or any other script interpreter to be run as root....and, as they can run other programs, it's equivalent to allowing ANY program to be run as root with any args.
    – cas
    Jan 23 at 4:33












  • 2




    It' yes, because anyone can write a Perl script to run any command as root. Just don't do it.
    – cuonglm
    Jan 23 at 2:58










  • this is no different to allowing perl or awk or bash or any other script interpreter to be run as root....and, as they can run other programs, it's equivalent to allowing ANY program to be run as root with any args.
    – cas
    Jan 23 at 4:33







2




2




It' yes, because anyone can write a Perl script to run any command as root. Just don't do it.
– cuonglm
Jan 23 at 2:58




It' yes, because anyone can write a Perl script to run any command as root. Just don't do it.
– cuonglm
Jan 23 at 2:58












this is no different to allowing perl or awk or bash or any other script interpreter to be run as root....and, as they can run other programs, it's equivalent to allowing ANY program to be run as root with any args.
– cas
Jan 23 at 4:33




this is no different to allowing perl or awk or bash or any other script interpreter to be run as root....and, as they can run other programs, it's equivalent to allowing ANY program to be run as root with any args.
– cas
Jan 23 at 4:33










1 Answer
1






active

oldest

votes

















up vote
3
down vote



accepted










Yes, that approach is insecure.



Write a specific wrapper that specifically runs your command which subsequently calls the prove, secure it so that only root can modify it, and put it somewhere only root can reach. Then, add that wrapper to the sudoers file.



Don't allow parameters in your script.



NB: Although, even that's open to abuse, if someone can modify either the first perl script, or the backup script. Have to ensure everything in the chain is modifiable only by root.






share|improve this answer






















    Your Answer







    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "106"
    ;
    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',
    convertImagesToLinks: false,
    noModals: false,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );








     

    draft saved


    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f418990%2fis-it-insecure-to-make-perls-prove-command-nopasswd-in-sudoers-file%23new-answer', 'question_page');

    );

    Post as a guest






























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes








    up vote
    3
    down vote



    accepted










    Yes, that approach is insecure.



    Write a specific wrapper that specifically runs your command which subsequently calls the prove, secure it so that only root can modify it, and put it somewhere only root can reach. Then, add that wrapper to the sudoers file.



    Don't allow parameters in your script.



    NB: Although, even that's open to abuse, if someone can modify either the first perl script, or the backup script. Have to ensure everything in the chain is modifiable only by root.






    share|improve this answer


























      up vote
      3
      down vote



      accepted










      Yes, that approach is insecure.



      Write a specific wrapper that specifically runs your command which subsequently calls the prove, secure it so that only root can modify it, and put it somewhere only root can reach. Then, add that wrapper to the sudoers file.



      Don't allow parameters in your script.



      NB: Although, even that's open to abuse, if someone can modify either the first perl script, or the backup script. Have to ensure everything in the chain is modifiable only by root.






      share|improve this answer
























        up vote
        3
        down vote



        accepted







        up vote
        3
        down vote



        accepted






        Yes, that approach is insecure.



        Write a specific wrapper that specifically runs your command which subsequently calls the prove, secure it so that only root can modify it, and put it somewhere only root can reach. Then, add that wrapper to the sudoers file.



        Don't allow parameters in your script.



        NB: Although, even that's open to abuse, if someone can modify either the first perl script, or the backup script. Have to ensure everything in the chain is modifiable only by root.






        share|improve this answer














        Yes, that approach is insecure.



        Write a specific wrapper that specifically runs your command which subsequently calls the prove, secure it so that only root can modify it, and put it somewhere only root can reach. Then, add that wrapper to the sudoers file.



        Don't allow parameters in your script.



        NB: Although, even that's open to abuse, if someone can modify either the first perl script, or the backup script. Have to ensure everything in the chain is modifiable only by root.







        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited Jan 23 at 8:35

























        answered Jan 23 at 8:25









        EightBitTony

        15.5k34353




        15.5k34353






















             

            draft saved


            draft discarded


























             


            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f418990%2fis-it-insecure-to-make-perls-prove-command-nopasswd-in-sudoers-file%23new-answer', 'question_page');

            );

            Post as a guest













































































            Popular posts from this blog

            How to check contact read email or not when send email to Individual?

            How many registers does an x86_64 CPU actually have?

            Nur Jahan