Hi Davide,

Thanks for the thorough response, but I think you're over
dimensioning, and to some extent missing, my initial purpose and
intention.

I don't want to protect from somebody attempting to reverse engineer
my application, that's impossible (more so given your references).
I simply want to disable the option to open the IDE, even with all
tool menus disabled.

In Java if I deliver a .jar or .war anybody could reverse engineer it,
but launching it won't open the development environment.

For comparison with other Smalltalks I've used:
* VisualWorks enables the distribution of a "headless" IMAGE (and
parcels) without sources, if you revert that image to be headful all
source code will be decompiled using meaningless variables.
* Dolphin has the concept of SessionManager that is the entry point to
the image startup, if you save your image with a Headless Session
manager, then no GUI loop will start, same thing if you deploy as a
COM component.
* VAST produces its own ICX file where you can choose what to include
in it, it's not simply saving the image but building a new one from
within the development image, it's one step further.
* VSE had the SLL (similar to DLLs), if you don't bind the IDE's SLLs
then there is no way to start the IDE (I never built a headless VSE
app though).

So what I'd like is an always Pharo headless image or Pharo headless
vm, instead of being controlled by a parameter in the VM.

Regards,

Esteban A. Maringolo

On Mon, Sep 7, 2020 at 12:04 PM Davide Grandi <davide.gra...@email.it> wrote:
>
> Ok, I'll give you a result, meanwhile fixing some imprecisions.
>
> The "class" is CogVmSimulator but it's use is very far from my knowlegde,
> I recalled having seen a picture of Pharo-in-Pharo (or Squeak-in-Squeak)
> running under this simulator.
> It lives near the Cog side (or the OpenVM side) of Squeak/Pharo
> (If I'm not wrong Squeak ran into an emulator, before walking on his
> legs-his VM).
>
> There are many of these simulator, for other Smalltalk :
> - Hobbes and others for Xerox (thanks to files of Mario Molczko and/or
>    Bitsavers
> - Dan Ingalls Apda Smalltalk + old Smalltalk -72 /-76
> and maybe others I don't yet know about
>
> The reason is quite simple : the object memory is written to disk
> and the spec of executing Smalltalk are known either from the books
> or by the source.
>
> The root is Xerox's SystemTracer, a class that wrote a running image
> to disk, optionally changing object format (see the Green Book).
>
> So :
> - if you can read the image
> - you can run into a simulator
> - or decode it without to much effort (5 emulators for Xerox V2 image,
> so far).
> (try to open an image with a text editor : intriguing !)
>
> I don't know how Cincom or Instantiations protect the released st code,
> but for Pharo and Squeak this is not a point : they are all open.
>
> So, as if you wanna "protect" names and methods of a running image ...
> ... you have to (IMHO) :
> - encrypt executable and image (and modify the VM)
> - or obfuscate your classes and methods renaming it to
>    C1, C2, ..., m1:p1:p2: and so on (keeping a map for debugging)
>
> Sorry to be imprecise about names and locations
> apart from suggest to see 4 emulators 4 running in a squeak image
> running ... in javascript in your browser (so total is 5) at :
> https://smalltalkzoo.thechm.org/HOPL-Squeak.html?earlyst80
> (thanks to Vanessa Freudemberg & Dan Ingalls).
>
> Sorry again & best regards,
>
>      Davide Grandi
>
> On 06/09/2020 23:51, Esteban Maringolo wrote:
> > If somebody gets to open the image and loads it with an Smalltalk
> > Emulator to execute it I'll ask him/her to start working together, and
> > even teach me how to do it.
> >
> > I don't want to shield the image from being accessed, just want to
> > make it harder than simply removing the '--headless' parameter to the
> > VM executable.
> > Of course removing sources is a plus (I do for a VW deployed image),
> > but even for this particular piece of software that I'm asking for, I
> > don't need it.
> >
> > If I wanted to make the source public, I'll publish it in
> > Github/Gitlab, otherwise I'd rather keep the code private.
> >
> > Regards,
> >
> > Esteban A. Maringolo
> >
> > On Sun, Sep 6, 2020 at 6:29 PM Davide Grandi <davide.gra...@email.it> wrote:
> >> I mean that with SmalltalkEmulator, the Smalltalk interpreter
> >> written in Smalltalk, one can execute an image looking at
> >> classes, methods and maybe executing code at will.
> >>
> >> And the only practical form of protection I see in Squeak/Pharo
> >> is to obfuscate code.
> >>
> >> Maybe I'm wrong.
> >>
> >>       Davide Grandi
> >>
> >> On 06/09/2020 22:27, Esteban Maringolo wrote:
> >>> On Sun, Sep 6, 2020 at 12:52 PM Davide Grandi <davide.gra...@email.it> 
> >>> wrote:
> >>>> Does "competition" has SmalltalkEmulator ?
> >>>> A Smalltalk-written VM will defeat any simple obfuscation scheme.
> >>> Sorry, but I don't understand what you  mean.
> >>>
> >>> Best regards,
> >> --
> >> Ing. Davide Grandi
> >> email    : davide.gra...@email.it
> >> mobile   : +39 339 7468 778
> >> linkedin : http://linkedin.com/in/davidegrandi
>
> --
> Ing. Davide Grandi
> email    : davide.gra...@email.it
> mobile   : +39 339 7468 778
> linkedin : http://linkedin.com/in/davidegrandi
>
>

Reply via email to