• Login
sketchucation logo sketchucation
  • Login
๐Ÿ”Œ Quick Selection | Try Didier Bur's reworked classic extension that supercharges selections in SketchUp Download

Between different Macs plugin works and doesn't work

Scheduled Pinned Locked Moved Developers' Forum
48 Posts 6 Posters 1.4k Views 6 Watching
Loading More Posts
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • S Offline
    slbaumgartner
    last edited by 14 Feb 2014, 00:54

    @mwm5053 said:

    I can't help you guys much sorry not a code man, but just some input if I may, the problem slbaumgartner is Lion 1.7.5 for me not MT Lion maybe it has a problem too. If Java is the culprit I have it enabled in Safari prefs but globally disabled in System Pref if that helps any.

    Sorry, I didn't read back carefully to see exactly which versions of Mac OS were giving the problems.

    But Javascript is completely unrelated to Java other than via an unfortunate choice of name. Your java settings have no effect on this.

    Steve

    1 Reply Last reply Reply Quote 0
    • S Offline
      slbaumgartner
      last edited by 15 Feb 2014, 02:04

      The reduced javascript code sends 'http error ' + xmlHttp.status back to Ruby and Ruby displays it in a UI.messagebox. The screenshots Walt posted on the other topic show that this callback arrived at Ruby correctly, so the problem is not with asynchronous javascript vs Ruby.

      Most of the incidents of status 0 reported on the web attribute it to cross-domain requests. That is, for security reasons XMLHttpRequest does not allow requests to be sent to a domain other than the original one. I wonder if there is a bug (or maybe a "feature") in WebKit on Lion that made it less tolerant of this, for example, concluding that since the html and its scripts were loaded locally only the localhost should be allowed? I confess that even after reading a lot about this I don't quite understand it...

      Garry, have you tried catching the onerror event? I wonder if it would tell you what is wrong when things fail on Walt's Mac..

      Steve

      1 Reply Last reply Reply Quote 0
      • G Offline
        Garry K
        last edited by 15 Feb 2014, 08:12

        I'm not sure that there is an http error. A value of 0 suggests that the call did not go beyond the computer. This suggests that it is possible that it has something to do with cross-domain requests. However, Sketchup does have the allow_actions_from_host which was set. I thought allow_actions_from_host was specifically for that, in otherwords to reduce security risks by allowing 1 and 1 only external call.

        What we could do is rem out the "loaded" part where we add the listener for DOMContentLoaded and replace that with a button and push the data to a hidden field.

        Then there is but one call back going in one direction. Now if that doesn't work then we have ruled out this being an asynchronous timing thing.

        Any thoughts?

        1 Reply Last reply Reply Quote 0
        • S Offline
          slbaumgartner
          last edited by 15 Feb 2014, 13:20

          @garry k said:

          I'm not sure that there is an http error. A value of 0 suggests that the call did not go beyond the computer. This suggests that it is possible that it has something to do with cross-domain requests. However, Sketchup does have the allow_actions_from_host which was set. I thought allow_actions_from_host was specifically for that, in otherwords to reduce security risks by allowing 1 and 1 only external call.

          What we could do is rem out the "loaded" part where we add the listener for DOMContentLoaded and replace that with a button and push the data to a hidden field.

          Then there is but one call back going in one direction. Now if that doesn't work then we have ruled out this being an asynchronous timing thing.

          Any thoughts?

          Rambling thoughts...

          I've become convinced that it is not an async timing problem. I also don't think it is an http error per-se, since those report three-digit codes (your javascript labels it an "http error", not the system). I suspect the request is being killed within the javascript library without ever going to the server. Have you checked the server logs to see whether they get traffic when Walt's system logs the error? My guess is no.

          I didn't find any discussion about ways for client-side code to turn off the blocking of cross-domain requests,
          only server-side headers that could be returned. It seems unlikely that there is a way for client code to disable the action, since that would make it essentially useless! What good is having a lock on the door if you provide a turn button to disengage it? So, I'd be surprised if SU's allow_actions_from_host defeats this particular security feature (or if it does, I'd like to know how - this is another of the poorly explained features of the API).

          From what I read, at least on many web libraries, XMLHttpRequest has an onerror event handler you can set that may provide a description of what went wrong. Something like

          
          xmlHttpRequest.onerror = function(e) {alert("request error; " + e.status.text)};
          
          

          It may be that the error message also shows up on a javascript console, if people with the problem can get one open before running the plugin.

          Steve

          1 Reply Last reply Reply Quote 0
          • S Offline
            slbaumgartner
            last edited by 15 Feb 2014, 15:46

            More thoughts: I don't think it is allow_actions_from_host. From what I looked up, that setting controls whether skp: callbacks are allowed from WebDialog contents loaded from a remote host. It is a sort of whitelist that gates whether skp: will work (and actually did nothing on OS X prior to Mavericks!). But clearly you are getting callbacks from javascript to Ruby ok. I still think it is most likely a change in handling of the AJAX cross-domain security in Lion vs later OS X. And I have no clue how to work around it ๐Ÿ˜ž

            1 Reply Last reply Reply Quote 0
            • T Offline
              TIG Moderator
              last edited by 15 Feb 2014, 16:45

              If a webdialog is not connecting to a server across the Internet you should never need to specify dlg.allow_actions_from_host(host) at all...
              If you do need to use it, then make sure that its argument is a 'domain' - like 'sketchucation.com' - and not an 'http-address' - like 'http://sketchucation.com'.
              On PCs and non-Mavericks MACs this difference was not a critical matter, but mis-setting it will surely break your webdialogs under the stricter Safari shipped with the new Mavericks.
              So it's best to ensure that a valid 'domain' is used...

              TIG

              1 Reply Last reply Reply Quote 0
              • S Offline
                slbaumgartner
                last edited by 15 Feb 2014, 18:13

                Garry,

                You might want to try out some of the CORS methods described in this article:

                https://developer.mozilla.org/en-US/docs/HTTP/Access_control_CORS

                1 Reply Last reply Reply Quote 0
                • G Offline
                  Garry K
                  last edited by 15 Feb 2014, 19:33

                  Jeff and Walt

                  I changed this based on what TIG said.

                  Please try it


                  modified dialog_test.rb

                  1 Reply Last reply Reply Quote 0
                  • M Offline
                    mwm5053
                    last edited by 15 Feb 2014, 20:51

                    This is what I get Garry


                    Screen Shot 2014-02-15 at 1.46.02 PM.png

                    2011 iMac
                    SU 2015 Pro, 2017 Make
                    V2 Twilight
                    macOS Sierra 10.12.5

                    1 Reply Last reply Reply Quote 0
                    • G Offline
                      Garry K
                      last edited by 15 Feb 2014, 21:14

                      Just to be sure - you downloaded the latest dialog_test.rb and line 10 now says:
                      @dlg.allow_actions_from_host( 'cabmaker32.com/ ' );

                      1 Reply Last reply Reply Quote 0
                      • M Offline
                        mwm5053
                        last edited by 15 Feb 2014, 21:20

                        Yes Garry I deleted the other one and installed the the new one.


                        Screen Shot 2014-02-15 at 2.15.53 PM.png

                        2011 iMac
                        SU 2015 Pro, 2017 Make
                        V2 Twilight
                        macOS Sierra 10.12.5

                        1 Reply Last reply Reply Quote 0
                        • S Offline
                          slbaumgartner
                          last edited by 15 Feb 2014, 21:44

                          @garry k said:

                          Just to be sure - you downloaded the latest dialog_test.rb and line 10 now says:
                          @dlg.allow_actions_from_host( 'cabmaker32.com/ ' );

                          Trailing slash not needed. Just 'cabmaker32.com '

                          1 Reply Last reply Reply Quote 0
                          • T Offline
                            TIG Moderator
                            last edited by 15 Feb 2014, 21:45

                            Remove the final / in the domain name. ๐Ÿ˜•

                            TIG

                            1 Reply Last reply Reply Quote 0
                            • G Offline
                              Garry K
                              last edited by 16 Feb 2014, 15:29

                              Jeff and Walt

                              I have now removed the trailing slash from cabmaker32.com on line 10

                              Maybe this will work.
                              Please try it


                              cleaned up the domain address

                              1 Reply Last reply Reply Quote 0
                              • M Offline
                                mwm5053
                                last edited by 16 Feb 2014, 15:35

                                Got the same error, sorry wish I could be of more help

                                2011 iMac
                                SU 2015 Pro, 2017 Make
                                V2 Twilight
                                macOS Sierra 10.12.5

                                1 Reply Last reply Reply Quote 0
                                • S Offline
                                  slbaumgartner
                                  last edited by 16 Feb 2014, 23:20

                                  @mwm5053 said:

                                  Got the same error, sorry wish I could be of more help

                                  Walt,

                                  Do you have the WebKit inspector activated? If not, please open a Terminal window and type

                                  defaults write <bundleid> WebKitDeveloperExtras -bool true

                                  where you replace <bundleid> with:
                                  com.google.sketchupfree8 for v8 Free
                                  com.google.sketchuppro8 for v8 Pro (what your info says you have)
                                  com.sketchup.SketchUp for 2013

                                  After doing that, please run Garry's test script and while the WebDialog labeled "connect to website" is still open, right-click on it and select "Inspect Element" from the popup menu. This will open the WebKit Inspector. The GUI of the WebKit Inspector has changed with version, but look for something labeled "Console" and click it. Please let us know if the Console displays any error or warning messages.

                                  Thanks
                                  Steve

                                  1 Reply Last reply Reply Quote 0
                                  • M Offline
                                    mwm5053
                                    last edited by 17 Feb 2014, 02:49

                                    @ Steve When I right click in Connect to Website all I get is "Reload" but this is what Terminal looks like after pressing return in terminal was that right?


                                    Screen Shot 2014-02-16 at 7.45.45 PM.png

                                    2011 iMac
                                    SU 2015 Pro, 2017 Make
                                    V2 Twilight
                                    macOS Sierra 10.12.5

                                    1 Reply Last reply Reply Quote 0
                                    • S Offline
                                      slbaumgartner
                                      last edited by 17 Feb 2014, 03:11

                                      @mwm5053 said:

                                      @ Steve When I right click in Connect to Website all I get is "Reload" but this is what Terminal looks like after pressing return in terminal was that right?

                                      The Terminal screenshot looks as if you left off part of the command. Did you type the entire line

                                      defaults write com.google.sketchuppro8 WebKitDeveloperExtras -bool true

                                      I forgot to mention that before entering this command you should quit SketchUp and restart it afterward. Until the default takes hold the right-click menu will only contain "Reload".

                                      Steve

                                      1 Reply Last reply Reply Quote 0
                                      • M Offline
                                        mwm5053
                                        last edited by 17 Feb 2014, 03:24

                                        I double checked the terminal and retyped and restated SU still no right click web inspector?


                                        Screen Shot 2014-02-16 at 8.19.17 PM.png

                                        2011 iMac
                                        SU 2015 Pro, 2017 Make
                                        V2 Twilight
                                        macOS Sierra 10.12.5

                                        1 Reply Last reply Reply Quote 0
                                        • S Offline
                                          slbaumgartner
                                          last edited by 17 Feb 2014, 03:28

                                          @mwm5053 said:

                                          I double checked the terminal and retyped and restated SU still no right click web inspector?

                                          Missed it again! You typed com.google.sketchup8pro, it should be com.google.sketchuppro8

                                          Steve

                                          1 Reply Last reply Reply Quote 0
                                          • 1
                                          • 2
                                          • 3
                                          • 1 / 3
                                          1 / 3
                                          • First post
                                            20/48
                                            Last post
                                          Buy SketchPlus
                                          Buy SUbD
                                          Buy WrapR
                                          Buy eBook
                                          Buy Modelur
                                          Buy Vertex Tools
                                          Buy SketchCuisine
                                          Buy FormFonts

                                          Advertisement