HISE Logo Forum
    • Categories
    • Register
    • Login

    New API: Server and FileSystem

    Scheduled Pinned Locked Moved General Questions
    71 Posts 8 Posters 5.8k Views
    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.
    • ustkU
      ustk @Christoph Hart
      last edited by ustk

      @Christoph-Hart I am currently removing (poor) server and file additions I've made these last days.
      Although I also have a delete file method:

      bool ScriptingApi::Engine::deleteFile(String fileName)
      {
      	File f;
      
      	if (File::isAbsolutePath(fileName))
      		f = File(fileName);
      	else
      		f = File(GET_PROJECT_HANDLER(getProcessor()).getSubDirectory(ProjectHandler::SubDirectories::UserPresets).getChildFile(fileName));
      
      	if (f.existsAsFile())
      		return f.deleteFile();
      
      	return false;
      }
      

      Maybe you want to add it to the File API so I can also remove mine?

      Can't help pressing F5 in the forum...

      1 Reply Last reply Reply Quote 0
      • Christoph HartC
        Christoph Hart @d.healey
        last edited by

        @d-healey Actually I was just checking whether there are any merge conflicts, but I need to get the CLAs from all contributors before I can merge your branch. The real task will be merging the new SNEX code...

        @ustk sure, I‘ll add it. I‘m a bit hesitant with the delete method because it‘s not undoable...

        d.healeyD ustkU 2 Replies Last reply Reply Quote 1
        • d.healeyD
          d.healey @Christoph Hart
          last edited by

          @Christoph-Hart said in New API: Server and FileSystem:

          I need to get the CLAs from all contributors before I can merge your branch.

          Just me, @ustk, and @Levitanus I think.

          Libre Wave - Freedom respecting instruments and effects
          My Patreon - HISE tutorials
          YouTube Channel - Public HISE tutorials

          1 Reply Last reply Reply Quote 0
          • ustkU
            ustk @Christoph Hart
            last edited by ustk

            @Christoph-Hart I tested the server with no success...

            This:

            // Prepare the parameters
            local parameters =
            {
                "request":      requestType,
                "email":        emailLbl.get("text"),
                "serial_key":   serialLbl.get("text"),
                "product_id":   productId,
                "instance":     instance
            };
            
            // Make the call
            Server.callWithGET(SerialNumbersAPI, parameters, function(status, response)    // SerialNumbersAPI is my sub...
            {
                Console.print(status);
                Console.print(trace(response));
            });
            

            Throws that

            Interface:! Expected '{' or '[': "1"
            Interface: 500
            Interface: {
              "error": "Expected '{' or '[': \"1\""
            }
            

            It shouldn't be because of the baseURL, subURL, or parameters because it worked before with my API...

            Can't help pressing F5 in the forum...

            1 Reply Last reply Reply Quote 0
            • Christoph HartC
              Christoph Hart
              last edited by

              Do you return a plain text? Because it expects JSON data

              ustkU 1 Reply Last reply Reply Quote 0
              • ustkU
                ustk @Christoph Hart
                last edited by

                @Christoph-Hart What do you mean? the response is an object:

                Server.callWithGET(SerialNumbersAPI, parameters, function(status, response)
                    {
                        Console.print(status);
                        Console.print(response);
                    });
                
                Interface:! Expected '{' or '[': "1"
                Interface: 500
                Interface: Object 0x423cc0
                
                

                Can't help pressing F5 in the forum...

                1 Reply Last reply Reply Quote 0
                • ustkU
                  ustk
                  last edited by

                  And:

                      Server.callWithGET(SerialNumbersAPI, parameters, function(status, response)
                      {
                          
                      });
                  

                  gives

                  Interface:! Expected '{' or '[': "1"
                  

                  Can't help pressing F5 in the forum...

                  1 Reply Last reply Reply Quote 0
                  • Christoph HartC
                    Christoph Hart
                    last edited by

                    Well the error message is wrapped in an object, but your actual server response throws a JSON parsing error.

                    ustkU 3 Replies Last reply Reply Quote 0
                    • ustkU
                      ustk @Christoph Hart
                      last edited by

                      @Christoph-Hart Which means?
                      Are the parameters not good? it all strings

                      Can't help pressing F5 in the forum...

                      1 Reply Last reply Reply Quote 0
                      • ustkU
                        ustk @Christoph Hart
                        last edited by ustk

                        @Christoph-Hart
                        Here's my habitual call
                        https://www.studio427audio.com/?wc-api=serial-numbers-api&request=check&...

                        here's what I set

                        Server.setBaseURL("https://www.studio427audio.com");
                        const var SerialNumbersAPI = "?wc-api=serial-numbers-api";    // subURL
                        

                        Can't help pressing F5 in the forum...

                        1 Reply Last reply Reply Quote 0
                        • Christoph HartC
                          Christoph Hart
                          last edited by Christoph Hart

                          That's not the sub-URL these are the GET arguments. Your sub URL is empty if you call the domain directly (haven't checked whether this works though, in my experience I've always called a sub URL). The parameter object should be

                          const var p =
                          {
                              "wc-api": "serial-numbers-api",
                              "request": "check"
                          };
                          
                          Server.setBaseURL("https://www.studio427audio.com");
                          Server.callWithGET("/", p, function(status, response)
                          {
                          
                          });
                          

                          But what does the server return? If it's just a plain old text, it won't work so you need to make sure your server returns a JSON file.

                          ustkU 2 Replies Last reply Reply Quote 1
                          • ustkU
                            ustk @Christoph Hart
                            last edited by

                            @Christoph-Hart I noticed in your example, the call adds a question mark at the end of the subURL.
                            I don't know if it's added or not to my url, but I know I shouldn't have one...

                            Can't help pressing F5 in the forum...

                            1 Reply Last reply Reply Quote 0
                            • ustkU
                              ustk @Christoph Hart
                              last edited by

                              @Christoph-Hart I see! testing...

                              Can't help pressing F5 in the forum...

                              1 Reply Last reply Reply Quote 0
                              • Christoph HartC
                                Christoph Hart
                                last edited by

                                This works here:

                                Content.makeFrontInterface(600, 500);
                                
                                const var p =
                                {
                                    "wc-api": "serial-numbers-api",
                                    "request": "check"
                                };
                                
                                reg r;
                                
                                Server.setBaseURL("https://www.studio427audio.com");
                                Server.callWithGET("/", p, function(status, response)
                                {
                                    r = response;
                                });
                                

                                If you check r in the script watch table, it contains

                                1 Reply Last reply Reply Quote 0
                                • ustkU
                                  ustk @Christoph Hart
                                  last edited by

                                  @Christoph-Hart Yeah! Working! :)
                                  I didn't know the api is par of GET arguments, though it was the sub...
                                  It works like a charm! Thanks!

                                  Can't help pressing F5 in the forum...

                                  1 Reply Last reply Reply Quote 0
                                  • Christoph HartC
                                    Christoph Hart
                                    last edited by

                                    Yes, the GET arguments will be embedded into the URL and POST data will be sent along with it. If your server supports it I'd recommend using POST data for sending authentification information as the other one is visible throughout the communication (which makes your SSL certificate pointless).

                                    ustkU 1 Reply Last reply Reply Quote 1
                                    • ustkU
                                      ustk @Christoph Hart
                                      last edited by ustk

                                      @Christoph-Hart Yes that's what I intended to do once the most simple part works :)

                                      Can't help pressing F5 in the forum...

                                      1 Reply Last reply Reply Quote 0
                                      • Christoph HartC
                                        Christoph Hart
                                        last edited by

                                        FYI, I just added the deleteFileOrDirectory() function...

                                        ustkU 1 Reply Last reply Reply Quote 1
                                        • Casey KolbC
                                          Casey Kolb
                                          last edited by

                                          This is awesome! Have been waiting for these features. Bravo!!

                                          Casey Kolb
                                          Founder & CEO of Lunacy Audio
                                          Composer | Producer | Software Developer

                                          1 Reply Last reply Reply Quote 1
                                          • ustkU
                                            ustk @Christoph Hart
                                            last edited by

                                            @Christoph-Hart Did someone tinkered with the File APIs?
                                            I tried getFolder and findFiles with no success.
                                            I put a *.js on the Desktop and used the location wildcard but findFiles returns an empty array...

                                            FileSystem.getFolder("Desktop");
                                            var fileList = FileSystem.findFiles("Desktop", "*.js", true)
                                            

                                            My end goal is to dump an encrypted file (but I don't see a dump file method except for the ol'dumpJSON of course)

                                            Can't help pressing F5 in the forum...

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            21

                                            Online

                                            1.8k

                                            Users

                                            12.0k

                                            Topics

                                            104.8k

                                            Posts