X-CGP-ClamAV-Result: CLEAN X-VirusScanner: Niversoft's CGPClamav Helper v1.25a (ClamAV 0.103.9/27062) X-Junk-Score: 0 [] X-KAS-Score: 0 [] Return-Path: Received: from mail01.rucotec.ch ([65.21.159.64] verified) by post.selbstdenker.com (CommuniGate Pro SMTP 6.3.18) with ESMTPS id 31439483 for webobjects-dev@wocommunity.org; Sun, 15 Oct 2023 13:19:47 +0200 Received-SPF: pass receiver=post.selbstdenker.com; client-ip=65.21.159.64; envelope-from=markus.ruggiero@rucotec.ch Received: from [127.0.0.1] (localhost [127.0.0.1]) by localhost (Mailerdaemon) with ESMTPSA id CC1E65E025; Sun, 15 Oct 2023 13:19:25 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=rucotec.ch; s=dkim; t=1697368766; h=from:subject:date:message-id:to:cc:mime-version:content-type: in-reply-to:references; bh=/ai3Yemkjnbnzu64q4aqJ5lHYiceYpLJtHrHNJMd8Zk=; b=osyCrMPP29SvTcx72YGrX6RnoNVmnQBVNW5g9kLlsBII8lP+JRZ66jC3GZcO6whEhIzOnE J17ac5otNAWZMmhccWnko4fPej6X7vG3yDOflbmivkbBhqOrw32n2JT9g7D2xDQs3lpZIo fF5acLy6dp5K3DM1OuaziSOel5soENy7gVvhDcwhb/dFyfOaybul/6fXjlzjnGwRKbyT+s B+39cRW0B0QzBLzKVikMjKM/Ptk2L03HesKqj3nbL49dLXeBT2ANNepEpJQzAEy3f8/Y5U G5Oe0xGDV4BzSjT6VbXJexePoK+1JpoEg4PQl3x/QGMZaB149VQSrH/num0pVQ== From: "Markus Ruggiero (rucotec)" Message-Id: Content-Type: multipart/signed; boundary="Apple-Mail=_29347B3F-C2BB-4679-BB23-C136C1E7B6B3"; protocol="application/pkcs7-signature"; micalg=sha-256 Mime-Version: 1.0 (Mac OS X Mail 16.0 \(3731.700.6\)) Subject: Re: [WO-DEV] ERJars collision with 3rd party jar Date: Sun, 15 Oct 2023 13:19:12 +0200 In-Reply-To: <9E6B7EE9-7C38-4882-8712-316007975554@chatnbike.com> Cc: Aaron Rosenzweig To: WebObjects & WOnder Development References: <9E6B7EE9-7C38-4882-8712-316007975554@chatnbike.com> X-Last-TLS-Session-Version: TLSv1.2 --Apple-Mail=_29347B3F-C2BB-4679-BB23-C136C1E7B6B3 Content-Type: multipart/alternative; boundary="Apple-Mail=_A8847F95-4BE5-40C9-857A-4A1BEF0A51F4" --Apple-Mail=_A8847F95-4BE5-40C9-857A-4A1BEF0A51F4 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset=utf-8 Thanks all for your help. I ended up patching ERJars. Seems to work and I have not yet found any = issues. Aaron, No Jenkins/Hudson involved, just plain conventional local ant build. The problem was / is that when I create a new Wonder application ERJars = is included automatically but seems to be injected into the class path = after the added twilio jar. Then things work. However my real app uses = tons of other Wonder frameworks as well as a couple locally built Wonder = based company specific frameworks (which might include AND EXPORT stuff = that interferes here) . In this scenario when building the final product = ERJars is injected at least partially further up in the class path = shadowing the 3rd party included classes. Twilio provides 2 pre-built jars, one with the Twilio stuff only and one = that includes all dependencies. I tried both and had all kind of issues. = Twilio only of course misses the dependencies whereas Twilio with its = various dependencies seems to become =E2=80=9Cscattered=E2=80=9D around = the class path and at least partially ends up below ERJars. So I put the stuff Twilio depends on into ERJars which seems to work = now=F0=9F=A4=9E. Yeah, Maven is the way to go but most probably wouldn=E2=80=99t have = helped in this scenario. > On 14 Oct 2023, at 02:07, Aaron Rosenzweig = wrote: >=20 > Hi Markus,=20 >=20 > Maven isn=E2=80=99t a silver bullet, you don=E2=80=99t have to go to = it at this moment and doing so may not solve your issues anyway. If you = have some code that uses an old API and other code that uses a newer API = you will be in a pickle.=20 >=20 > I didn=E2=80=99t fully understand what you said. On the one hand, you = were able to get the twillio jar loaded first in Eclipse and things were = good. Then you said no matter how you rearrange, it didn=E2=80=99t work. = So which is it? Could you rearrange or not?=20 >=20 > Perhaps you are saying that within Eclipse you can rearrange and get = things to work=E2=80=A6 and maybe in Jenkins/Hudson (if you are using = that) you can=E2=80=99t get it to build. I don=E2=80=99t know, I=E2=80=99m= only guessing. If this is indeed the case then maybe in the short term = you can build the .woa from Eclipse and upload that until you fix = Jenkins.=20 >=20 > Hope you get it figured out. It must be very frustrating.=20 >=20 >> On Oct 12, 2023, at 5:14 PM, Markus Ruggiero (rucotec) = > wrote: >>=20 >> I have a big (?) problem. >>=20 >> We have a rather complex Wonder app built from several custom = frameworks and a ton of Wonder frameworks. That=E2=80=99s all good so = far. But now I need to include a 3rd party jar for sending out SMS/text = (twilio.com ). I created a simple out-of-the-box = Wonder application and included that jar as a library. The app includes = the standard ERJar framework. When I run the app I get a crash because = the twilio lib makes a call to some Apache httpclient stuff that does = not exist in ERJar (it is obviously newer). I can get a built jar = including all dependencies from twilio. Adding this to my project = instead of the =E2=80=9Cnaked=E2=80=9D one I still get the same crash. = BUT reordering the class path in Eclipse so that twilio lib comes before = ERJars makes everything work. >>=20 >> So I tried to include that complete twilio jar into my big Wonder = App. But no matter what I do, I always get the crash that something in = httpclient cannot be resolved. Dumping java.class.path clearly shows = that ERJar is before my library, not matter how I try to rearrange the = class path. So it seem that in my complex setup with included other = custom frameworks ERJar is always moved further up and thus shadows the = newer classes (why does this not happen with the initial simple Hello = World app?) >>=20 >> How can I resolve this class path issue? All my projects are still = ant-based.=20 >>=20 >> Please don=E2=80=99t tell me to switch to maven! I simply do not have = the time to convert everything. I started to read up on maven but then = urgent issues and required new functionality took all my time away. And = as long as I could make things work easily there was no need to go = maven. So for the sake of my schedule I really hope there is a way to = get that stuff working in my ant setup, at least for the time being. >>=20 >> Any ideas? >> Thanks a lot >> ---markus--- >>=20 >=20 --Apple-Mail=_A8847F95-4BE5-40C9-857A-4A1BEF0A51F4 Content-Transfer-Encoding: quoted-printable Content-Type: text/html; charset=utf-8 Thanks all for = your help.

I ended up patching ERJars. Seems to work = and I have not yet found any = issues.

Aaron,
No Jenkins/Hudson = involved, just plain conventional local ant build.
The problem = was / is that when I create a new Wonder application ERJars is included = automatically but seems to be injected into the class path after the = added twilio jar. Then things work. However my real app uses tons of = other Wonder frameworks as well as a couple locally built Wonder based = company specific frameworks (which might include AND EXPORT stuff that = interferes here) . In this scenario when building the final product = ERJars is injected at least partially further up in the class path = shadowing the 3rd party included classes.
Twilio provides 2 = pre-built jars, one with the Twilio stuff only and one that includes all = dependencies. I tried both and had all kind of issues. Twilio only of = course misses the dependencies whereas Twilio with its various = dependencies seems to become =E2=80=9Cscattered=E2=80=9D around the = class path and at least partially ends up below ERJars.
So I = put the stuff Twilio depends on into ERJars which seems to work = now=F0=9F=A4=9E.

Yeah, Maven is the way to go = but most probably wouldn=E2=80=99t have helped in this = scenario.

On 14 Oct 2023, at = 02:07, Aaron Rosenzweig <aaron@chatnbike.com> wrote:

Hi = Markus, 

Maven isn=E2=80=99t a silver bullet, = you don=E2=80=99t have to go to it at this moment and doing so may not = solve your issues anyway. If you have some code that uses an old API and = other code that uses a newer API you will be in a = pickle. 

I didn=E2=80=99t fully understand = what you said. On the one hand, you were able to get the twillio jar = loaded first in Eclipse and things were good. Then you said no matter = how you rearrange, it didn=E2=80=99t work. So which is it? Could you = rearrange or not? 

Perhaps you are saying = that within Eclipse you can rearrange and get things to work=E2=80=A6 = and maybe in Jenkins/Hudson (if you are using that) you can=E2=80=99t = get it to build. I don=E2=80=99t know, I=E2=80=99m only guessing. If = this is indeed the case then maybe in the short term you can build the = .woa from Eclipse and upload that until you fix = Jenkins. 

Hope you get it figured out. It = must be very frustrating. 

On Oct 12, 2023, at 5:14 PM, = Markus Ruggiero (rucotec) <markus.ruggiero@rucotec.ch&= gt; wrote:

I have a big (?) = problem.

We have a rather complex Wonder app built = from several custom frameworks and a ton of Wonder frameworks. That=E2=80=99= s all good so far. But now I need to include a 3rd party jar for sending = out SMS/text (twilio.com). I created a = simple out-of-the-box Wonder application and included that jar as a = library. The app includes the standard ERJar framework. When I run the = app I get a crash because the twilio lib makes a call to some Apache = httpclient stuff that does not exist in ERJar (it is obviously newer). I = can get a built jar including all dependencies from twilio. Adding this = to my project instead of the =E2=80=9Cnaked=E2=80=9D one I still get the = same crash. BUT reordering the class path in Eclipse so that twilio lib = comes before ERJars makes everything work.

So I = tried to include that complete twilio jar into my big Wonder App. But no = matter what I do, I always get the crash that something in httpclient = cannot be resolved. Dumping java.class.path clearly shows that ERJar is = before my library, not matter how I try to rearrange the class path. So = it seem that in my complex setup with included other custom frameworks = ERJar is always moved further up and thus shadows the newer classes (why = does this not happen with the initial simple Hello World = app?)

How can I resolve this class path = issue? All my = projects are still ant-based. 

Please don=E2=80=99t tell me to switch to maven! I simply = do not have the time to convert everything. I started to read up on = maven but then urgent issues and required new functionality took all my = time away. And as long as I could make things work easily there was no = need to go maven. So for the sake of my schedule I really hope there is = a way to get that stuff working in my ant setup, at least for the time = being.

Any ideas?
Thanks a = lot
---markus---
=



= --Apple-Mail=_A8847F95-4BE5-40C9-857A-4A1BEF0A51F4-- --Apple-Mail=_29347B3F-C2BB-4679-BB23-C136C1E7B6B3 Content-Disposition: attachment; filename=smime.p7s Content-Type: application/pkcs7-signature; name=smime.p7s Content-Transfer-Encoding: base64 MIAGCSqGSIb3DQEHAqCAMIACAQExDzANBglghkgBZQMEAgEFADCABgkqhkiG9w0BBwEAAKCCCzow ggUiMIIECqADAgECAhEA+bJBRVU88Wt+/tk032YQpDANBgkqhkiG9w0BAQsFADCBljELMAkGA1UE BhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEYMBYG A1UEChMPU2VjdGlnbyBMaW1pdGVkMT4wPAYDVQQDEzVTZWN0aWdvIFJTQSBDbGllbnQgQXV0aGVu dGljYXRpb24gYW5kIFNlY3VyZSBFbWFpbCBDQTAeFw0yMjA1MTQwMDAwMDBaFw0yNTA1MTMyMzU5 NTlaMCsxKTAnBgkqhkiG9w0BCQEWGm1hcmt1cy5ydWdnaWVyb0BydWNvdGVjLmNoMIIBIjANBgkq hkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAmyWv+KHiux3seusiaMG6GkTnzpAtZAQoNEuUSF/NCltV 8vC5c5mSp3S9nwQwd9vsncR35LsmXWCxDFE/EsOPr8q/ulmuN2DFxar17CoQzR2WkOJ4hn60FjuS gXuQMW2UsdRBajEqaMtmPKmFV3KN4wLi9fQLzve5Psykv+da4TUI5QB1y/1d1F00co+k5Xq16xXG Mq2kBLRpo3+ykiLJHKx/1YVTDhhrT72jkcGcc6GjUINbtqV0Z84m3PC26eOUoSGIqKSOls8GnmQY AA/al1OPBI5AjCh+sxq9MCNtTs4EJW4+sMmZE4CRY/60odb++HxdsRuAwYdqfg5fjHPqvQIDAQAB o4IB0zCCAc8wHwYDVR0jBBgwFoAUCcDy/AvalNtf/ivfqJlCz8ngrQAwHQYDVR0OBBYEFNt3xL6+ uF93aKx7OyZ+5X0tJkOiMA4GA1UdDwEB/wQEAwIFoDAMBgNVHRMBAf8EAjAAMB0GA1UdJQQWMBQG CCsGAQUFBwMEBggrBgEFBQcDAjBABgNVHSAEOTA3MDUGDCsGAQQBsjEBAgEBATAlMCMGCCsGAQUF BwIBFhdodHRwczovL3NlY3RpZ28uY29tL0NQUzBaBgNVHR8EUzBRME+gTaBLhklodHRwOi8vY3Js LnNlY3RpZ28uY29tL1NlY3RpZ29SU0FDbGllbnRBdXRoZW50aWNhdGlvbmFuZFNlY3VyZUVtYWls Q0EuY3JsMIGKBggrBgEFBQcBAQR+MHwwVQYIKwYBBQUHMAKGSWh0dHA6Ly9jcnQuc2VjdGlnby5j b20vU2VjdGlnb1JTQUNsaWVudEF1dGhlbnRpY2F0aW9uYW5kU2VjdXJlRW1haWxDQS5jcnQwIwYI KwYBBQUHMAGGF2h0dHA6Ly9vY3NwLnNlY3RpZ28uY29tMCUGA1UdEQQeMByBGm1hcmt1cy5ydWdn aWVyb0BydWNvdGVjLmNoMA0GCSqGSIb3DQEBCwUAA4IBAQBbChLqbBr/EGVvqY3JhZltmRwUBagV XqgrWDgMk3xqkXlPVBucGuRq/wg2sCZBUVQFDXoIiyFrCjQy5A80F3fJ+H/dr8M4KT5hMrPSrsj9 dTQP9T7MnluDRuhma5+x9vSvMIttSD1EhkHJsSvGw0BH2BOrUsqQJP5k2bEa9j8faLZaJRUbQG0G zpZnLUrRbhnndW5OEdKa+F5x9lkWM/Lj0eiEdkYoJJPnD/JF3uqAn12U3FZI4yv+K6IxA9M0kn/M Vxm0AVEdYDsgIkbBI+BhS1QWsOxC4utrY3A2nfLtY0RrbcR7g8B4N/QbD657Wrb7i45485+yYZon cp6nqFwyMIIGEDCCA/igAwIBAgIQTZQsENQ74JQJxYEtOisGTzANBgkqhkiG9w0BAQwFADCBiDEL MAkGA1UEBhMCVVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4w HAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBSU0EgQ2Vy dGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMTgxMTAyMDAwMDAwWhcNMzAxMjMxMjM1OTU5WjCBljEL MAkGA1UEBhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9y ZDEYMBYGA1UEChMPU2VjdGlnbyBMaW1pdGVkMT4wPAYDVQQDEzVTZWN0aWdvIFJTQSBDbGllbnQg QXV0aGVudGljYXRpb24gYW5kIFNlY3VyZSBFbWFpbCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEP ADCCAQoCggEBAMo87ZQKQf/e+Ua56NY75tqSvysQTqoavIK9viYcKSoq0s2cUIE/bZQu85eoZ9X1 40qOTKl1HyLTJbazGl6nBEibivHbSuejQkq6uIgymiqvTcTlxZql19szfBxxo0Nm9l79L9S+TZNT EDygNfcXlkHKRhBhVFHdJDfqB6Mfi/Wlda43zYgo92yZOpCWjj2mz4tudN55/yE1+XvFnz5xsOFb me/SoY9WAa39uJORHtbC0x7C7aYivToxuIkEQXaumf05Vcf4RgHs+Yd+mwSTManRy6XcCFJE6k/L Ht3ndD3sA3If/JBz6OX2ZebtQdHnKav7Azf+bAhudg7PkFOTuRMCAwEAAaOCAWQwggFgMB8GA1Ud IwQYMBaAFFN5v1qqK0rPVIDh2JvAnfKyA2bLMB0GA1UdDgQWBBQJwPL8C9qU21/+K9+omULPyeCt ADAOBgNVHQ8BAf8EBAMCAYYwEgYDVR0TAQH/BAgwBgEB/wIBADAdBgNVHSUEFjAUBggrBgEFBQcD AgYIKwYBBQUHAwQwEQYDVR0gBAowCDAGBgRVHSAAMFAGA1UdHwRJMEcwRaBDoEGGP2h0dHA6Ly9j cmwudXNlcnRydXN0LmNvbS9VU0VSVHJ1c3RSU0FDZXJ0aWZpY2F0aW9uQXV0aG9yaXR5LmNybDB2 BggrBgEFBQcBAQRqMGgwPwYIKwYBBQUHMAKGM2h0dHA6Ly9jcnQudXNlcnRydXN0LmNvbS9VU0VS VHJ1c3RSU0FBZGRUcnVzdENBLmNydDAlBggrBgEFBQcwAYYZaHR0cDovL29jc3AudXNlcnRydXN0 LmNvbTANBgkqhkiG9w0BAQwFAAOCAgEAQUR1AKs5whX13o6VbTJxaIwA3RfXehwQOJDI47G9FzGR 87bjgrShfsbMIYdhqpFuSUKzPM1ZVPgNlT+9istp5UQNRsJiD4KLu+E2f102qxxvM3TEoGg65FWM 89YN5yFTvSB5PelcLGnCLwRfCX6iLPvGlh9j30lKzcT+mLO1NLGWMeK1w+vnKhav2VuQVHwpTf64 ZNnXUF8p+5JJpGtkUG/XfdJ5jR3YCq8H0OPZkNoVkDQ5CSSF8Co2AOlVEf32VBXglIrHQ3v9AAS0 yPo4Xl1FdXqGFe5TcDQSqXh3TbjugGnG+d9yZX3lB8bwc/Tn2FlIl7tPbDAL4jNdUNA7jGee+tAn TtlZ6bFz+CsWmCIb6j6lDFqkXVsp+3KyLTZGXq6F2nnBtN4t5jO3ZIj2gpIKHAYNBAWLG2Q2fG7B t2tPC8BLC9WIM90gbMhAmtMGquITn/2fORdsNmaV3z/sPKuIn8DvdEhmWVfh0fyYeqxGlTw0Rfwh BlakdYYrkDmdWC+XszE19GUi8K8plBNKcIvyg2omAdebrMIHiAHAOiczxX/aS5ABRVrNUDcjfvp4 hYbDOO6qHcfzy/uY0fO5ssebmHQREJJA3PpSgdVnLernF6pthJrGkNDPeUI05svqw1o5A2HcNzLO pklhNwZ+4uWYLcAi14ACHuVvJsmzNicxggPHMIIDwwIBATCBrDCBljELMAkGA1UEBhMCR0IxGzAZ BgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEYMBYGA1UEChMPU2Vj dGlnbyBMaW1pdGVkMT4wPAYDVQQDEzVTZWN0aWdvIFJTQSBDbGllbnQgQXV0aGVudGljYXRpb24g YW5kIFNlY3VyZSBFbWFpbCBDQQIRAPmyQUVVPPFrfv7ZNN9mEKQwDQYJYIZIAWUDBAIBBQCgggHr MBgGCSqGSIb3DQEJAzELBgkqhkiG9w0BBwEwHAYJKoZIhvcNAQkFMQ8XDTIzMTAxNTExMTkxMlow LwYJKoZIhvcNAQkEMSIEIDBT/SMNhIWNL8xdXPHAmzYoGWNjHeOHHm9DK9Vt99C7MIG9BgkrBgEE AYI3EAQxga8wgawwgZYxCzAJBgNVBAYTAkdCMRswGQYDVQQIExJHcmVhdGVyIE1hbmNoZXN0ZXIx EDAOBgNVBAcTB1NhbGZvcmQxGDAWBgNVBAoTD1NlY3RpZ28gTGltaXRlZDE+MDwGA1UEAxM1U2Vj dGlnbyBSU0EgQ2xpZW50IEF1dGhlbnRpY2F0aW9uIGFuZCBTZWN1cmUgRW1haWwgQ0ECEQD5skFF VTzxa37+2TTfZhCkMIG/BgsqhkiG9w0BCRACCzGBr6CBrDCBljELMAkGA1UEBhMCR0IxGzAZBgNV BAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEYMBYGA1UEChMPU2VjdGln byBMaW1pdGVkMT4wPAYDVQQDEzVTZWN0aWdvIFJTQSBDbGllbnQgQXV0aGVudGljYXRpb24gYW5k IFNlY3VyZSBFbWFpbCBDQQIRAPmyQUVVPPFrfv7ZNN9mEKQwDQYJKoZIhvcNAQELBQAEggEAgzcn JwvOFfRVEwNqtqlJKzIt3B0WdftlzCA3MLYQcbDBwLpzDzSn5Ssfs2ElDcQGY5DC5s2EJVf/haca H20rN0Ne3kKppFwztVWieyrVwZ+67c6ipIktkQtPuDje+ipgGG6F943yoJBP67yW34tbU5BAK1T5 h+uGFhexkee3/oCGDnFgQXF7ETesGbjAV/Ix7M8qodx6FanB1S3XpcRcAaR4vSMF6T6FU5b5fwU6 zXYgzGdR5qm5qpnclePDzAAH2EvWru78ZmHJdz9qyBiJqTIOCnSlqKuQ/5r+U7NbAPhHsPnFd3Do pWlb3/BguaLBS3tgyC1pdcafUocaCA5RywAAAAAAAA== --Apple-Mail=_29347B3F-C2BB-4679-BB23-C136C1E7B6B3--