Here's a puzzler. I am trying to write a script which can handle plugins, so that installing a plugin is as easy as downloading it and putting it in a specific directory - the script will automatically detect and use it at several points.

One requirement is security: I think this is satisified by making sure the directory can only be written to by the owner of the script, so if he/she puts stupid stuff in there, that's his or her fault. Another requirement, pulling the other way, is future-proofing: it should be able to handle upgrades and plugins I haven't thought of yet. A final requirement is ease of use: no renaming stuff, no command line fiddling, just download and go.

My initial thought is as follows:

I have some worries about this.

(1) Is it really secure?

(2) I don't seem to be using the Perl module system very effectively, except to distinguish between different plugins' $can_be_called_from hashes.

Can anyone suggest an improvement, or some useful thoughts about this architecture problem? Either Perl-specific comments, or general ideas, are welcome.

Cheers,
Dave


In reply to architecture for module API by dash2

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.