rjsf-team / react-jsonschema-form

A React component for building Web forms from JSON Schema.
https://rjsf-team.github.io/react-jsonschema-form/
Apache License 2.0
14.14k stars 2.18k forks source link

5.3.0: Array items perform much worse #3517

Open MatinF opened 1 year ago

MatinF commented 1 year ago

Prerequisites

What theme are you using?

core

Version

5.0.0-beta.18 vs. 5.0.0-beta.19

Current Behavior

We wanted to test out the latest update to rjsf (upgrading from 5.0.0 beta11 to 5.3.0) in order to benefit from the new ability to 'copy' array items, which was added as a feature in the latest release.

Unfortunately, the performance of the updated version is much worse when it comes to adding/removing array items - to an extent where it now takes ~1-2 seconds to add a new entry, up from <0.1 seconds in the previous release. After isolating the release introducing this, it seems to start after 5.0.0-beta.18.

I am unable to replicate this in the live playground, though I am unsure why.

Expected Behavior

I would expect the performance to be similar to previous versions.

Steps To Reproduce

1) Use a standard rjsf setup with 5.0.0-beta.18 vs. 5.0.0-beta.19

2) Use below custom array template:

3) To replicate this, test with the below formdata (config) and schema/uischema. The slow performance can be seen by going to CAN CH1 and adding entries in the Transmit list section. json-schema.zip

nickgros commented 1 year ago

@MatinF I tried to re-create this in CodeSandbox and didn't notice issues with array performance https://codesandbox.io/s/rjsf-3517-repro-679s2u

Can you create your own example or modify the above so we can get to the bottom of this (or clarify further how to see the issue if it is present in that example)?

MatinF commented 1 year ago

I've been trying to replicate your dependency setup in my own application, but struggling to achieve this due to some legacy dependencies. I recognize that there is not a performance issue in your sandbox, so I am not sure why there is on my side.

The app I'm testing this with is below: https://github.com/CSS-Electronics/config-editor-base

You can install it by running npm install in the root and in the example/ folder, followed by running npm start in both folders. If you then load attached configuration file you'll be able to load up the editor: config-01.07.zip

I'm guessing the issue is related to some of the outdated dependencies I have, such as React 16.0.0 and other things. I tried various steps such as updating from validator v6 to v8 as in your sandbox, but the slow performance persists.

As you can see if you decide to install the app, the performance is snappy with the default version of rjsf in the repository - but if you update to 5.3.0 it becomes much slower.

heath-freenome commented 1 year ago

@MatinF Wow that a lot of code you've written. I don't really have time to analyze and inspect it all to find the issue for you. I'm wondering if you are experiencing an interaction in your own code with react rerendering? Have you been able to debug into the RJSF code to see if it is there? Also, I just fixed an issue in 5.5.1 that prevented infinite recursions when using a schema with recursive refs. Can you check to see if that helped.

Cauen commented 1 year ago

@heath-freenome @nickgros Only by updating core to v5+, starts a performance problem on your example...

MatinF commented 1 year ago

I tested this with my own repository, config-editor-base, installing v5.5.2 of all the rjsf modules - but the performance issue remains unaffected. I think the issue is linked to some change made after 5.0.0-beta.18.

heath-freenome commented 1 year ago

I tested this with my own repository, config-editor-base, installing v5.5.2 of all the rjsf modules - but the performance issue remains unaffected. I think the issue is linked to some change made after 5.0.0-beta.18.

From what you shared the problem started in 5.0.0-beta.19 right?

Cauen commented 1 year ago

@heath-freenome 5.0.0-beta.1 in my tests. You can check by only changing version in codesandbox

heath-freenome commented 1 year ago

@Cauen First off, I haven't had a chance to dig deep into your example yet. Basically you are saying that v5 has performance issues that v4 doesn't have. A lot changed between 4 and 5. Are you willing to slowly reduce the size/complexity of the schema in example until the performance issue seems to go away and then put back the bit that causes it? Or, better yet, are you able to debug the current codebase enough to find out where the issue is happening? I basically only get a few hours on the weekend to tackle stuff and this seems like a large thing to tackle. Thanks

MatinF commented 1 year ago

@heath-freenome Fully understand that this is a rather cumbersome thing to test. I did specifically go through each revision on my end and can confirm for certain that it starts after 5.0.0-beta.18 - i.e. with 5.0.0-beta.19 being the first time I experience the problem. It is very clear cut. Every subsequent release has the same issue. I did not experience it in versions prior to 5.0.0-beta.19, though.

heath-freenome commented 1 year ago

@MatinF Are you using liveOmit and omitExtraData? We just added support for the OpenAPI discriminator for oneOf and anyOf. This could speed up your example a bunch. We are only supporting the propertyName of discriminator, and not the mappings. Using your schema, here's an updated fragment:

dependencies: {
        id_format: {
          discriminator: {
            propertyName: "id_format"
          },
          oneOf: [
            {
              properties: {
                id_format: {
                  enum: [0]
                },
                id: {
                  pattern: "^([0-7][a-fA-F0-9]{2}|[a-fA-F0-9]{1,2})$",
                  maxLength: 3
                },
                id_mask: {
                  pattern: "^([0-7][a-fA-F0-9]{2}|[a-fA-F0-9]{1,2})$",
                  maxLength: 3
                }
              }
            },
            {
              properties: {
                id_format: {
                  enum: [1]
                },
                id: {
                  pattern: "^([0-1][a-fA-F0-9]{7}|[a-fA-F0-9]{1,7})$",
                  maxLength: 8
                },
                id_mask: {
                  pattern: "^([0-1][a-fA-F0-9]{7}|[a-fA-F0-9]{1,7})$",
                  maxLength: 8
                }
              }
            }
          ]
        }
      },
      additionalProperties: false,
      required: ["chn", "id_format", "id", "id_mask"]
    },
MatinF commented 1 year ago

Hi again,

Yes, we use both of those, see below:

<FormWithNav
               validator={validator}
                omitExtraData={true}
                liveOmit={true}
                liveValidate={true}
                noHtml5Validate={true}
                schema={schemaContent ? schemaContent : {}}
                uiSchema={uiContent ? uiContent : {}}
                formData={configContent ? configContent : {}}
                onSubmit={this.onSubmit}
                onChange={this.handleChange}
                onError={this.handleError}
                onNavChange={this.onNavChange.bind(this)}
                templates={{ArrayFieldTemplate}}
                activeNav={activatedTab}
              >

I'm not sure how I would go about testing the impact of the OpenAPI discriminator you mention?

As mentioned before, we have never had any performance issues at all until the specific update 5.0.0-beta.19, i.e. I don't think this is related to an under-performing implementation in the Rule Schema, but rather I think this is due to some change implemented within that update that somehow affects our Rule Schema particularly hard.

heath-freenome commented 1 year ago

@MatinF So the release you have pointed to fixed a bug with toPathSchema() so that it handled oneOf/anyOf schemas (before that it didn't). toPathSchema() is used to computed what fields need to be checked in the liveOmit/omitExtraData. So it make sense that you experienced a slow-down when this fix was added. There definitely were issues with recursive references significantly slowing down the toPathSchema() function but those were fixed. The reason I suggested using the Open API descriptor is that it would speed up the detection of the schema that matches formData when there is a oneOf that contains objects that rely on the selection being based on that value of a single field of that object.

If you were to check out the speed of your code before and after adding them, I would hope you will see a speed up of the UI

MatinF commented 1 year ago

Ok just to check: If I am to test the effect of this, would I be able to do so by simply disabling the liveOmit / omitExtraData and seeing if that suffices to fix the performance issues?

If that helps, how would I enable the use of the Open API descriptor? I'm not familiar with this, so I am unsure if this is a built in feature of rjsf, or a separate project?

heath-freenome commented 1 year ago

Ok just to check: If I am to test the effect of this, would I be able to do so by simply disabling the liveOmit / omitExtraData and seeing if that suffices to fix the performance issues?

If that helps, how would I enable the use of the Open API descriptor? I'm not familiar with this, so I am unsure if this is a built in feature of rjsf, or a separate project?

Yes, turning off both of those flags should gain you performance.

You need only add the open API descriptor to your schema and RJSF will detect and use it to speed up the selection of the oneOf based upon the single field. I can get on a discord call with you sometime to walk you through it if that helps.

MatinF commented 1 year ago

Hi again,

Just as a bit of an update on this topic: We have been further investigating potential ways to resolve the issue with array items for our Rule Schema. However, in the more recent versions of the playground, it appears that the overall performance with our Rule Schema has completely tanked. As such, I think something more fundamental is going on in terms of how our type of Rule Schema is handled in the more recent releases.

You can verify this via the playground link below.

As you should be able to verify, simply entering a value in the first field (or any field) comes with a massive "lag" of multiple seconds. This is not at all the case in the version we're currently running our own app with (i.e. the versions up until and excluding 5.0.0-beta.19).

I'm not sure it's the same thing causing this recently observed playground lag and the more array-related issue pointed out in this issue. However, I'm guessing there may be some related underlying factor - e.g. because our Schema may be considered "large" (87 kb) or heavily nested. Any inputs on this would be of great interest as we would like to be able to update to the latest versions, but the performance blocks this - now also evident from the playground itself

https://rjsf-team.github.io/react-jsonschema-form/#{"formData":{"general":{"device":{"meta":"sss"},"security":{},"debug":{"syslog":0}},"log":{"file":{"split_size":50,"split_time_period":0,"split_time_offset":0,"cyclic":1},"compression":{"level":0},"encryption":{"state":0},"error_frames":{"state":0}},"rtc":{"sync":2,"timezone":0,"adjustment":0,"tolerance":30,"ntp_server":"*.pool.ntp.org"},"secondaryport":{"power_schedule":[]},"can_internal":{"general":{"rx_state":1,"tx_state":1},"filter":{"id":[{"state":1,"type":0,"id_format":0,"method":0,"f1":"0","f2":"7FF"}]},"control":{"control_rx_state":0,"control_tx_state":0,"start":{"message":{"chn":0,"id_format":0,"id":"0","id_mask":"7FF"},"signal":{"type":0,"byteorder":1,"bitpos":0,"length":0,"factor":0,"offset":0},"trigger_high":0,"trigger_low":0},"stop":{"message":{"chn":0,"id_format":0,"id":"0","id_mask":"7FF"},"signal":{"type":0,"byteorder":1,"bitpos":0,"length":0,"factor":0,"offset":0},"trigger_high":0,"trigger_low":0}}},"can_1":{"general":{"rx_state":1,"tx_state":1},"phy":{"mode":1,"retransmission":1,"fd_spec":0,"bit_rate_cfg_mode":0},"filter":{"remote_frames":0,"id":[{"state":1,"type":0,"id_format":0,"method":0,"f1":"0","f2":"7FF"}]},"transmit":[],"heartbeat":{"state":0,"id_format":1,"id":"00435353"},"control":{"control_rx_state":0,"control_tx_state":0,"start":{"message":{"chn":0,"id_format":0,"id":"0","id_mask":"7FF"},"signal":{"type":0,"byteorder":1,"bitpos":0,"length":0,"factor":0,"offset":0},"trigger_high":0,"trigger_low":0},"stop":{"message":{"chn":0,"id_format":0,"id":"0","id_mask":"7FF"},"signal":{"type":0,"byteorder":1,"bitpos":0,"length":0,"factor":0,"offset":0},"trigger_high":0,"trigger_low":0}}},"can_2":{"general":{"rx_state":1,"tx_state":1},"phy":{"mode":1,"retransmission":1,"fd_spec":0,"bit_rate_cfg_mode":0},"filter":{"remote_frames":0,"id":[{"state":1,"type":0,"id_format":0,"method":0,"f1":"0","f2":"7FF"}]},"transmit":[],"heartbeat":{"state":0,"id_format":1,"id":"00435353"},"control":{"control_rx_state":0,"control_tx_state":0,"start":{"message":{"chn":0,"id_format":0,"id":"0","id_mask":"7FF"},"signal":{"type":0,"byteorder":1,"bitpos":0,"length":0,"factor":0,"offset":0},"trigger_high":0,"trigger_low":0},"stop":{"message":{"chn":0,"id_format":0,"id":"0","id_mask":"7FF"},"signal":{"type":0,"byteorder":1,"bitpos":0,"length":0,"factor":0,"offset":0},"trigger_high":0,"trigger_low":0}}},"lin_1":{"phy":{"mode":0,"bit_rate":19200},"frames":[],"transmit":[]},"lin_2":{"phy":{"mode":0,"bit_rate":19200},"frames":[],"transmit":[]},"connect":{"wifi":{"mode":0,"keyformat":0,"accesspoint":[]},"s3":{"sync":{"ota":600,"heartbeat":300,"logfiles":1},"server":{"request_style":0,"keyformat":0,"signed_payload":0}}},"test_object":{"my_string_field":""}},"schema":{"type":"object","definitions":{"can_message":{"type":"object","properties":{"chn":{"title":"Channel","description":"CAN-bus channel","type":"integer","default":0,"oneOf":[{"type":"integer","title":"CAN internal","enum":[0]},{"type":"integer","title":"CAN 1","enum":[1]},{"type":"integer","title":"CAN 2","enum":[2]}]},"id_format":{"title":"ID format","description":"ID format of message.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Standard (11-bit)","enum":[0]},{"type":"integer","title":"Extended (29-bit)","enum":[1]}]},"id":{"title":"ID (hex)","description":"ID of message in hex. Example: 1FF.","type":"string","default":"0"},"id_mask":{"title":"ID mask (hex)","description":"ID mask in hex. Example: 7FF.","type":"string","default":"7FF"}},"dependencies":{"id_format":{"oneOf":[{"properties":{"id_format":{"enum":[0]},"id":{"pattern":"^([0-7][a-fA-F0-9]{2}|[a-fA-F0-9]{1,2})$","maxLength":3},"id_mask":{"pattern":"^([0-7][a-fA-F0-9]{2}|[a-fA-F0-9]{1,2})$","maxLength":3}}},{"properties":{"id_format":{"enum":[1]},"id":{"pattern":"^([0-1][a-fA-F0-9]{7}|[a-fA-F0-9]{1,7})$","maxLength":8},"id_mask":{"pattern":"^([0-1][a-fA-F0-9]{7}|[a-fA-F0-9]{1,7})$","maxLength":8}}}]}},"additionalProperties":false,"required":["chn","id_format","id","id_mask"]},"can_signal":{"type":"object","properties":{"type":{"title":"Signal type","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Unsigned","enum":[0]}]},"byteorder":{"title":"Signal byteorder","description":"Can be Motorola (big endian) or Intel (little endian)","type":"integer","default":1,"oneOf":[{"type":"integer","title":"Motorola","enum":[0]},{"type":"integer","title":"Intel","enum":[1]}]},"bitpos":{"title":"Signal bit position","type":"integer","default":0,"minimum":0,"maximum":512},"length":{"title":"Signal bit length","type":"integer","default":0,"minimum":0,"maximum":64},"factor":{"title":"Signal scaling","type":"number","default":0},"offset":{"title":"Signal offset","type":"number","default":0}},"additionalProperties":false,"required":["type","byteorder","bitpos","length","factor","offset"]},"can_control_startstop":{"type":"object","properties":{"message":{"title":"Message","$ref":"#/definitions/can_message"},"signal":{"title":"Signal","$ref":"#/definitions/can_signal"},"trigger_high":{"title":"Trigger high (dec)","type":"number","default":0},"trigger_low":{"title":"Trigger low (dec)","type":"number","default":0}},"additionalProperties":false,"required":["message","signal","trigger_high","trigger_low"]},"can_filter_id":{"title":"ID filters","type":"array","minItems":1,"items":{"type":"object","properties":{"name":{"title":"Name","description":"Optional filter name.","type":"string","pattern":"^[ -~]*$","maxLength":16},"state":{"title":"State","description":"Disabled filters are ignored.","type":"integer","default":1,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]},"type":{"title":"Type","description":"Action on match, accept or reject message.","type":"integer","default":0,"oneOf":[{"title":"Acceptance","enum":[0]},{"title":"Rejection","enum":[1]}]},"id_format":{"title":"ID format","description":"Filter ID format. Filters apply to messages with matching ID format.","type":"integer","default":0,"oneOf":[{"title":"Standard (11-bit)","enum":[0]},{"title":"Extended (29-bit)","enum":[1]}]},"method":{"title":"Filter method","description":"The filter ID matching mechanism.","type":"integer","default":0,"oneOf":[{"title":"Range","enum":[0],"description":"ID ranges"},{"title":"Mask","enum":[1],"description":"ID masking"}]},"f1":{"title":"From (range) / ID (mask) (HEX)","description":"If filter method is Range, this field defines the start of range. If filter method is Mask, this field defines the filter ID.","type":"string","pattern":"^[a-fA-F0-9]+$","maxLength":8,"default":"0"},"f2":{"title":"To (range) / mask (mask) (HEX)","description":"If filter method is Range, this field defines the end of range. If filter method is Mask, this field defines the filter mask.","type":"string","pattern":"^[a-fA-F0-9]+$","maxLength":8,"default":"7FF"}},"dependencies":{"type":{"oneOf":[{"properties":{"type":{"enum":[0]},"prescaler_type":{"title":"Prescaling type","description":"Select prescaling type. Prescale by message count, time or data. Select None to disable prescaling.","type":"integer","default":0,"oneOf":[{"title":"None","enum":[0]},{"title":"Count","enum":[1]},{"title":"Time","enum":[2]},{"title":"Data","enum":[3]}]}},"dependencies":{"prescaler_type":{"oneOf":[{"properties":{"prescaler_type":{"enum":[0]}}},{"properties":{"prescaler_type":{"enum":[1]},"prescaler_value":{"title":"Count","type":"integer","description":"Count prescaler value. Example: Set to 2 to sample a message with a specific ID every second time.","default":1,"minimum":1,"maximum":256}},"required":["prescaler_value"]},{"properties":{"prescaler_type":{"enum":[2]},"prescaler_value":{"title":"Time","description":"Time prescaler value in milliseconds. Example: Set to 1000 to sample a message with a specific ID with a minimum period time of 1 second. Note that messages are not resampled to a specific fixed period time.","type":"integer","default":1,"minimum":1,"maximum":4194304}},"required":["prescaler_value"]},{"properties":{"prescaler_type":{"enum":[3]},"prescaler_value":{"title":"Mask","description":"Data prescaler mask value in hex. Each bit corresponds to a data byte (up to 64 bytes). Leave empty to disable the mask (triggers on any data change). Example 1: Set to FF (0b11111111) to sample a message with a specific ID if any of the first 8 data bytes change. Example 2: Set to 03 (0b00000011) to sample if any of the two first data bytes change. Example 3: Set to 9 (0b00001001) to sample if any of the first or fourth data bytes change.","type":"string","default":"FF","pattern":"^[a-fA-F0-9]*$","maxLength":16}}}]}},"required":["prescaler_type"]},{"properties":{"type":{"enum":[1]}}}]}},"additionalProperties":false,"patternProperties":{"prescaler_type":{},"prescaler_value":{}},"required":["state","type","id_format","method","f1","f2"]}},"can_general":{"title":"General","description":"CAN bus general configuration","type":"object","properties":{"rx_state":{"title":"Reception (rx) initial state","description":"The initial state of CAN-bus reception. Can be changed using the control signal.","type":"integer","default":1,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]},"tx_state":{"title":"Transmission (tx) initial state","description":"The initial state of CAN-bus transmissions. Can be changed using the control signal.","type":"integer","default":1,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]}},"additionalProperties":false,"required":["rx_state","tx_state"]},"can_control":{"title":"Control","description":"Control signal","type":"object","properties":{"control_rx_state":{"title":"Control reception (rx) state","description":"Control CAN-bus reception state (including logging) ","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]},"control_tx_state":{"title":"Control transmission (tx) state","description":"Control CAN-bus transmission state (including logging) ","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]},"start":{"title":"Start","$ref":"#/definitions/can_control_startstop"},"stop":{"title":"Stop","$ref":"#/definitions/can_control_startstop"}},"required":["control_rx_state","control_tx_state","start","stop"]},"can":{"type":"object","properties":{"general":{"$ref":"#/definitions/can_general"},"phy":{"title":"Physical (CAN bus low-level)","description":"CAN bus low-level configuration","type":"object","properties":{"mode":{"title":"Mode","description":"Device CAN bus mode. Configures how the device interacts with the bus. In Normal mode, the device can receive, acknowledge and transmit frames. In Restricted mode, the device can receive and acknowledge, but not transmit frames. In Bus Monitoring mode, the device can receive, but not acknowledge or transmit frames. It is recommended to always use the most restrictive mode possible.","type":"integer","default":1,"oneOf":[{"type":"integer","title":"Normal (receive, acknowledge and transmit)","enum":[0]},{"type":"integer","title":"Restricted (receive and acknowledge)","enum":[1]},{"type":"integer","title":"Monitoring (receive only)","enum":[2]}]},"retransmission":{"title":"Automatic retransmission","description":"Retransmission of frames that have lost arbitration or that have been disturbed by errors during transmission.","type":"integer","default":1,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]},"fd_spec":{"title":"CAN FD specification","description":"Configures the CAN FD specification used by the device. Shall match the specification used by the CAN bus network.","type":"integer","default":0,"oneOf":[{"type":"integer","title":" ISO CAN FD (11898-1)","enum":[0]},{"type":"integer","title":"non-ISO CAN FD (Bosch V1.0.)","enum":[1]}]},"bit_rate_cfg_mode":{"title":"Bit-rate configuration mode","description":"Configures how the CAN bus bit-rate is set. Modes Auto-detect and Bit-rate support all standard bit-rates. Non-standard bit-rate configuration can be set using Bit-timing. It is recommended to set the bit-rate manually if it is known.","type":"integer","default":0,"oneOf":[{"title":"Auto-detect","enum":[0]},{"title":"Bit-rate (simple)","enum":[1]},{"title":"Bit-timing (advanced)","enum":[2]}]}},"dependencies":{"bit_rate_cfg_mode":{"oneOf":[{"properties":{"bit_rate_cfg_mode":{"enum":[0]}}},{"properties":{"bit_rate_cfg_mode":{"enum":[1]},"bit_rate_std":{"title":"Bit-rate standard","type":"integer","default":250000,"oneOf":[{"title":"5K","enum":[5000]},{"title":"10K","enum":[10000]},{"title":"20K","enum":[20000]},{"title":"33.333K","enum":[33333]},{"title":"47.619K","enum":[47619]},{"title":"50K","enum":[50000]},{"title":"83.333K","enum":[83333]},{"title":"95.238K","enum":[95238]},{"title":"100K","enum":[100000]},{"title":"125K","enum":[125000]},{"title":"250K","enum":[250000]},{"title":"500K","enum":[500000]},{"title":"800K","enum":[800000]},{"title":"1M","enum":[1000000]}]},"bit_rate_fd":{"title":"Bit-rate FD","type":"integer","default":1000000,"oneOf":[{"title":"1M","enum":[1000000]},{"title":"2M","enum":[2000000]},{"title":"4M","enum":[4000000]}]}},"required":["bit_rate_std","bit_rate_fd"]},{"properties":{"bit_rate_cfg_mode":{"enum":[2]},"bit_rate_std":{"title":"Bit-timing standard","type":"object","properties":{"brp":{"title":"BRP (Bit Rate Prescaler)","type":"integer","default":2,"minimum":1},"seg1":{"title":"SEG1 (Time Segment 1 )","type":"integer","default":63,"minimum":1},"seg2":{"title":"SEG2 (Time Segment 2)","type":"integer","default":16,"minimum":2},"sjw":{"title":"SJW (Synchronization Jump Width)","type":"integer","default":4,"minimum":0,"maximum":4}},"additionalProperties":false,"required":["brp","seg1","seg2","sjw"]},"bit_rate_fd":{"title":"Bit-timing FD","type":"object","properties":{"brp":{"title":"BRP (Bit Rate Prescaler)","type":"integer","default":1,"minimum":1},"seg1":{"title":"SEG1 (Time Segment 1)","type":"integer","default":31,"minimum":1},"seg2":{"title":"SEG2 (Time Segment 2)","type":"integer","default":8,"minimum":2},"sjw":{"title":"SJW (Synchronization Jump Width)","type":"integer","default":4,"minimum":0,"maximum":4}},"additionalProperties":false,"required":["brp","seg1","seg2","sjw"]}},"required":["bit_rate_std","bit_rate_fd"]}]}},"additionalProperties":false,"patternProperties":{"bit_rate_std":{},"bit_rate_fd":{}},"required":["mode","retransmission","fd_spec","bit_rate_cfg_mode"]},"filter":{"title":"Receive filters","type":"object","properties":{"remote_frames":{"title":"Filter remote request frames","description":"Controls if remote request frames are forwarded to the message filters. If `Reject` is selected, remote request frames are discarded before they reach the message filters.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Reject","enum":[0]},{"type":"integer","title":"Accept","enum":[1]}]},"id":{"description":"Filters are checked sequentially, execution stops with the first matching filter element. Max 128 11-bit filters and 64 29-bit filters.","maxItems":192,"$ref":"#/definitions/can_filter_id"}},"required":["remote_frames","id"]},"transmit":{"title":"Transmit messages","description":"List of CAN bus messages transmitted by the device. Requires a CAN-bus physical mode supporting transmissions.","type":"array","maxItems":64,"items":{"type":"object","properties":{"name":{"title":"Name","description":"Optional transmit message name.","type":"string","pattern":"^[ -~]*$","maxLength":16},"state":{"title":"State","description":"Disabled transmit messages are ignored.","type":"integer","default":1,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]},"id_format":{"title":"ID Format","description":"ID format of the transmit message.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Standard (11-bit)","enum":[0]},{"type":"integer","title":"Extended (29-bit)","enum":[1]}]},"frame_format":{"title":"Frame format","description":"Frame format of the transmit message.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Standard","enum":[0]},{"type":"integer","title":"Standard RTR","enum":[2]},{"type":"integer","title":"FD","enum":[1]}]},"brs":{"title":"Bit-Rate Switch","description":"Determines if an FD message is transmitted using a switched bit-rate.","type":"integer","default":0},"log":{"title":"Include in log","description":"Determines if the transmitted message is included in the log file.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]},"period":{"title":"Period (10 ms steps)","description":"Time period of the message transmission. 0: single shot, >0: periodic. Unit is ms.","type":"integer","minimum":0,"maximum":4294967290,"multipleOf":10},"delay":{"title":"Delay (10 ms steps)","description":"Offset message within the period or delay a single shot message. If multiple messages are transmitted by the device, it is recommended to offset each separately to reduce peak load on bus. If period > 0, delay < period. If single-shot, delay can be up to max value. Unit is ms.","type":"integer","minimum":0,"maximum":4294967290,"multipleOf":10},"id":{"title":"Message ID (hex)","description":"ID of message to transmit in hex. Example: 1FF.","type":"string"},"data":{"title":"Messages Data (hex)","description":"Data bytes of message to transmit. RTR frames only use the number of bytes do determine the DLC. Example: 01020304 or 0102030405060708. ","type":"string","pattern":"^([a-fA-F0-9]{2}){0,64}$","maxLength":128}},"dependencies":{"id_format":{"oneOf":[{"properties":{"id_format":{"enum":[0]},"id":{"pattern":"^([0-7][a-fA-F0-9]{2}|[a-fA-F0-9]{1,2})$","maxLength":3}}},{"properties":{"id_format":{"enum":[1]},"id":{"pattern":"^([0-1][a-fA-F0-9]{7}|[a-fA-F0-9]{1,7})$","maxLength":8}}}]},"frame_format":{"oneOf":[{"properties":{"frame_format":{"enum":[0]},"brs":{"oneOf":[{"type":"integer","title":"Disable","enum":[0]}]},"data":{"pattern":"^([a-fA-F0-9]{2}){0,8}$","maxLength":16}}},{"properties":{"frame_format":{"enum":[2]},"brs":{"oneOf":[{"type":"integer","title":"Disable","enum":[0]}]},"data":{"pattern":"^([a-fA-F0-9]{2}){0,8}$","maxLength":16}}},{"properties":{"frame_format":{"enum":[1]},"brs":{"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]},"data":{"pattern":"^([a-fA-F0-9]{2}){0,64}$","maxLength":128}}}]}},"additionalProperties":false,"required":["state","id_format","frame_format","brs","log","period","delay","id","data"]}},"heartbeat":{"title":"Heartbeat","description":"Periodic heartbeat (1 second period time). Requires a CAN-bus physical mode supporting transmissions.","type":"object","properties":{"state":{"title":"State","description":"Enable to periodically transmit heartbeat signal. ","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]},"id_format":{"title":"ID Format","description":"ID format of heartbeat message.","type":"integer","default":1,"oneOf":[{"type":"integer","title":"Standard (11-bit)","enum":[0]},{"type":"integer","title":"Extended (29-bit)","enum":[1]}]},"id":{"title":"ID (hex)","description":"ID of heartbeat message in hex. Example: 1FF.","type":"string","default":"00435353"}},"dependencies":{"id_format":{"oneOf":[{"properties":{"id_format":{"enum":[0]},"id":{"pattern":"^([0-7][a-fA-F0-9]{2}|[a-fA-F0-9]{1,2})$","maxLength":3}}},{"properties":{"id_format":{"enum":[1]},"id":{"pattern":"^([0-1][a-fA-F0-9]{7}|[a-fA-F0-9]{1,7})$","maxLength":8}}}]}},"required":["state","id_format","id"]},"control":{"$ref":"#/definitions/can_control"}},"additionalProperties":false,"required":["general","phy","filter"]},"lin":{"type":"object","properties":{"phy":{"title":"Physical (LIN bus low-level)","description":"LIN bus low-level configuration","type":"object","properties":{"mode":{"title":"Mode","description":"Device LIN bus mode.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Subscriber","enum":[0]},{"type":"integer","title":"Publisher","enum":[1]}]},"bit_rate":{"title":"Bit-rate","type":"integer","default":19200,"oneOf":[{"title":"2400","enum":[2400]},{"title":"9600","enum":[9600]},{"title":"10400","enum":[10400]},{"title":"19200","enum":[19200]}]}},"additionalProperties":false,"required":["mode","bit_rate"]},"frames":{"title":"LIN frames","description":"Custom description of the frames on the network, if not using automatic length and/or checksum.","type":"array","maxItems":64,"items":{"type":"object","properties":{"name":{"title":"Name","description":"Optional frame name.","type":"string","pattern":"^[ -~]*$","maxLength":16},"id":{"title":"Frame ID (hex)","description":"ID of frame in hex. Example: 0F.","type":"string","pattern":"^([0-7][a-fA-F0-9]|[a-fA-F0-9])$","maxLength":2},"length":{"title":"Frame Length (decimal)","description":"Length of the frame in decimal.","type":"integer","minimum":1,"maximum":8},"checksum_type":{"title":"Checksum Type","description":"Type of the checksum used on the LIN frame.","type":"integer","default":0,"oneOf":[{"title":"Enhanced","enum":[0]},{"title":"Classic","enum":[1]}]}},"additionalProperties":false,"required":["id","length","checksum_type"]}},"transmit":{"title":"LIN transmit list","description":"List of frames to transmit when in master mode.","type":"array","maxItems":64,"uniqueItems":true,"items":{"type":"object","properties":{"name":{"title":"Name","description":"Optional transmit rule name.","type":"string","pattern":"^[ -~]*$","maxLength":16},"state":{"title":"State","description":"Disabled transmit rules are ignored.","type":"integer","default":1,"oneOf":[{"title":"Disable","enum":[0]},{"title":"Enable","enum":[1]}]},"id":{"title":"Frame ID (hex)","type":"string","pattern":"^([0-7][a-fA-F0-9]|[a-fA-F0-9])$","maxLength":2},"data":{"title":"Data (hex)","type":"string","pattern":"^([a-fA-F0-9]{2})*$","maxLength":16}},"additionalProperties":false,"patternProperties":{"period":{},"delay":{}},"required":["state","id"]}}},"dependencies":{"phy":{"oneOf":[{"properties":{"phy":{"properties":{"mode":{"enum":[0]}}},"transmit":{"items":{"properties":{"id":{"description":"Unique ID of frame in hex (an ID may only occur once in the list). Example: 0F."},"data":{"description":"Data to transmit on request","minLength":2}},"required":["data"]}}}},{"properties":{"phy":{"properties":{"mode":{"enum":[1]}}},"transmit":{"items":{"properties":{"id":{"description":"ID of frame in hex. Example: 0F."},"data":{"description":"If more than zero data bytes, then the transmit is a PUBLISH frame. If zero data bytes, then the transmit is a SUBSCRIBE frame expecting a subscriber node to provide data. ","minLength":0},"period":{"title":"Period (10 ms steps)","description":"Time period of the message transmission. 0: single shot, >0: periodic. Unit is ms.","type":"integer","minimum":0,"maximum":4294967290,"multipleOf":10},"delay":{"title":"Delay (10 ms steps)","description":"Offset message within the period or delay a single shot message. If multiple messages are transmitted by the device, it is recommended to offset each separately to reduce peak load on bus. If period > 0, delay < period. If single-shot, delay can be up to max value. Unit is ms.","type":"integer","minimum":0,"maximum":4294967290,"multipleOf":10}},"required":["period","delay"]}}}}]}},"additionalProperties":false,"required":["phy"]},"rtc_tolerance":{"title":"Time synchronization tolerance","description":"If the time difference exceeds the tolerance, the internal time is abruptly updated. The unit is seconds.","type":"integer","minimum":1,"maximum":3600,"default":30}},"properties":{"general":{"title":"General","type":"object","properties":{"device":{"title":"Device","type":"object","properties":{"meta":{"title":"Meta data","description":"Optional meta data string. Displayed in device file and log file headers. Example: Site1; Truck4; ConfigRev12","type":"string","minLength":0,"maxLength":30,"pattern":"^[a-zA-Z0-9; ]*$"}},"additionalProperties":false},"security":{"title":"Security","type":"object","properties":{"kpub":{"title":"Server public key","description":"Server / user ECC public key in base64 format. Shall match the encryption used for all protected fields.","type":"string","minLength":0,"maxLength":100,"pattern":"^[a-zA-Z0-9+/=]*$"}},"additionalProperties":false},"debug":{"title":"Debug","description":"Debug functionality for use during installation and troubleshooting.","type":"object","properties":{"syslog":{"title":"System log","description":"System events logged to the SD-card. The log levels are listed in order of increasing amount of information logged. Should only be enabled if needed during installation or troubleshooting.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Disable (0)","enum":[0]},{"type":"integer","title":"Error (1)","enum":[1]},{"type":"integer","title":"Warning (2)","enum":[2]},{"type":"integer","title":"Info (3)","enum":[3]}]}},"additionalProperties":false}},"additionalProperties":false,"required":["device","security","debug"]},"log":{"title":"Logging","type":"object","properties":{"file":{"title":"File","type":"object","properties":{"split_size":{"title":"File split size (1 to 512 MB)","description":"Log file split size in MB. When the file split size is reached a new file is created and the logging continues. Closed log files can be pushed to a server if network is available. Small split sizes may reduce performance.","type":"integer","default":50,"minimum":1,"maximum":512},"split_time_period":{"title":"File split time period (0 to 86400 seconds, 0 = disable)","description":"Log file split time period in seconds relative to midnight (00:00:00). When a split time is reached a new file is created and the logging continues. Closed log files can be pushed to a server if network is available. Small split time periods may reduce performance.","type":"integer","default":0,"minimum":0,"maximum":86400,"multipleOf":10},"split_time_offset":{"title":"File split time offset (0 to 86400 seconds)","description":"Log file split time offset in seconds. This value offsets the split_time_period relative to midnight (00:00:00). The set value shall be less than the split_time_period value.","type":"integer","default":0,"minimum":0,"maximum":86400,"multipleOf":10},"cyclic":{"title":"Cyclic logging","description":"With cycling logging mode enabled the oldest log file is deleted when the memory card becomes full, allowing the logging to continue.","type":"integer","default":1,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]}},"additionalProperties":false,"required":["split_size","split_time_period","split_time_offset","cyclic"]},"compression":{"title":"Compression","type":"object","properties":{"level":{"title":"Level","description":"Window size used during optional compression. Larger window sizes yield potentially better compression rates, but may reduce logging performance. Compressed log files need to be decompressed prior to processing.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"256 bytes window","enum":[256]},{"type":"integer","title":"512 bytes window","enum":[512]},{"type":"integer","title":"1024 bytes window","enum":[1024]}]}}},"encryption":{"title":"Encryption","type":"object","properties":{"state":{"title":"State","description":"Optional log file encryption. Encrypted log files need to be decrypted prior to processing. Decryption requires your encryption password in plain form - if this is lost, the encrypted data cannot be recovered.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]}},"dependencies":{"state":{"oneOf":[{"properties":{"state":{"enum":[0]}}},{"properties":{"state":{"enum":[1]},"keyformat":{"title":"Key format","description":"The format of the encryption password used for encrypting logged data on the device.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Plain","enum":[0]},{"type":"integer","title":"Encrypted","enum":[1]}]},"pwd":{"title":"Encryption password","type":"string","default":""}},"dependencies":{"keyformat":{"oneOf":[{"properties":{"keyformat":{"enum":[0]},"pwd":{"description":"Encryption password in plain form (min 1, max 64). Example: 2e9asdKJazCatsssdS323@ABCh22. IMPORTANT: Ensure that you securely store the plain form encryption password for decryption purposes.","pattern":"^[ -~]*$","minLength":1,"maxLength":64}}},{"properties":{"keyformat":{"enum":[1]},"pwd":{"description":"Encryption password in encrypted form (min 24, max 108). Example: B1DlMrNh22tq/kNerK/T+eSyCWSJqiqyUoovQ7C6gqRaIng6F+E=. IMPORTANT: Ensure that you encrypt the encryption password and that you include the server public key. Further, ensure that you securely store the plain form encryption password for decryption purposes.","pattern":"^[a-zA-Z0-9+/=]*$","minLength":24,"maxLength":108}}}]}},"required":["keyformat","pwd"]}]}}},"error_frames":{"title":"Error Frames","type":"object","properties":{"state":{"title":"State","description":"Specify whether to record error frames. Enabling this can negatively impact performance, as a potentially large number of additional frames may be recorded.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]}},"required":["state"]}},"additionalProperties":false,"patternProperties":{"keyformat":{},"pwd":{}},"required":["file","compression","encryption","error_frames"]},"rtc":{"title":"Real-Time Clock (RTC)","type":"object","properties":{"sync":{"title":"Time synchronization method","description":"Internal real-time-clock synchronization method. The real-time-clock is maintained when the device is off.","type":"integer","default":2,"oneOf":[{"title":"Retain current time","description":"The current internal time is not changed.","type":"integer","enum":[0]},{"title":"Manual update","description":"The internal time is updated with the manually set UTC time when the device powers on. The manual time is set using the manual_date_time field","type":"integer","enum":[1]},{"title":"CAN-bus","description":"The internal time synchronized to the time provided by the payload of a CAN-bus message","type":"integer","enum":[3]},{"title":"Network","description":"The internal time is synchronized with the time provided by the network when available.","type":"integer","enum":[2]}]},"timezone":{"title":"Time zone (UTC-12 to UTC+14)","description":"Adjustment in full hours to the UTC time. Includes daylight savings time if applicable.","type":"integer","default":0,"minimum":-12,"maximum":14},"adjustment":{"title":"Adjustment (-129600 to 129600 seconds)","description":"Adjustment in seconds to the UTC time. Can be used for fine tuning the internal time. ","type":"integer","default":0,"minimum":-129600,"maximum":129600}},"dependencies":{"sync":{"oneOf":[{"properties":{"sync":{"enum":[0]}}},{"properties":{"sync":{"enum":[1]},"manual_date_time":{"title":"Time (UTC)","description":"Manually set UTC date and time value.","type":"string","format":"date-time"}},"required":["manual_date_time"]},{"properties":{"sync":{"enum":[3]},"tolerance":{"$ref":"#/definitions/rtc_tolerance"},"message":{"title":"Message","$ref":"#/definitions/can_message"},"valid_signal":{"title":"Time valid signal","$ref":"#/definitions/can_signal"},"time_signal":{"title":"Time value signal","$ref":"#/definitions/can_signal"}},"required":["message","valid_signal","time_signal"]},{"properties":{"sync":{"enum":[2]},"tolerance":{"$ref":"#/definitions/rtc_tolerance"},"ntp_server":{"title":"Time server","description":"NTP server name used for time synchronization. If the first character is an asterisk (*) then the server name is treated as a server pool. Examples:  *.pool.ntp.org, *.us.pool.ntp.org, time.nist.gov","type":"string","default":"*.pool.ntp.org","maxLength":32,"pattern":"^\\*?[a-z0-9\\.-]*$"}},"required":["ntp_server","tolerance"]}]}},"additionalProperties":false,"patternProperties":{"manual_date_time":{},"message":{},"valid_signal":{},"time_signal":{},"ntp_server":{},"tolerance":{}},"required":["sync","timezone","adjustment"]},"secondaryport":{"title":"Secondary Port","description":"Control of power-out (5V) on Channel 2 (CH2) connector.","type":"object","properties":{"power_schedule":{"title":"Power schedule","description":"The daily power schedule is defined by a number of power-on from/to intervals. Define no power-on intervals to keep always off. Define one interval with from/to both set to 00:00 to keep always on. Time format is HH:MM (1 minute resolution)","type":"array","default":[],"maxItems":5,"items":{"type":"object","properties":{"from":{"title":"From","description":"Power-on FROM time in format HH:MM. Shall be before power-on TO time. E.g. at midnight 00:00","type":"string","default":"00:00","pattern":"^([0-1][0-9]|2[0-4]):([0-5][0-9])$"},"to":{"title":"To","description":"Power-on TO time in format HH:MM. Shall be after power-on FROM time. E.g. at midday 12:00.","type":"string","default":"00:00","pattern":"^([0-1][0-9]|2[0-4]):([0-5][0-9])$"}},"additionalProperties":false,"required":["from","to"]}}},"additionalProperties":false,"required":["power_schedule"]},"can_internal":{"title":"CAN Channel internal","description":"CAN Channel internal is a virtual channel used for signals generated by the device itself.","type":"object","properties":{"general":{"title":"General","$ref":"#/definitions/can_general"},"filter":{"title":"Receive filters","type":"object","properties":{"id":{"description":"Filters are checked sequentially, execution stops with the first matching filter element. Max 20 filters in total.","maxItems":20,"$ref":"#/definitions/can_filter_id"}},"required":["id"]},"control":{"$ref":"#/definitions/can_control"}},"additionalProperties":false,"required":["filter"]},"can_1":{"title":"CAN Channel 1 (physical)","description":"CAN Channel 1 is an external physical channel.","$ref":"#/definitions/can"},"can_2":{"title":"CAN Channel 2 (physical)","description":"CAN Channel 2 is an external physical channel.","$ref":"#/definitions/can"},"lin_1":{"title":"LIN Channel 1","$ref":"#/definitions/lin"},"lin_2":{"title":"LIN Channel 2","$ref":"#/definitions/lin"},"connect":{"title":"Connectivity","type":"object","properties":{"wifi":{"title":"WiFi","type":"object","properties":{"mode":{"title":"Mode","description":"In station mode, the device can use either active or passive scanning to find APs. Using active scan, the radio transmits a probe request and listens for responses. Using passive scan, the radio listens on each channel for beacons sent periodically by APs.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Station mode (active scanning)","enum":[0]},{"type":"integer","title":"Station mode (passive scanning)","enum":[1]}]},"keyformat":{"title":"Key format","description":"The format of the key used for all entries in the access point list. Can be used to hide the WiFi passwords stored on the device.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Plain","enum":[0]},{"type":"integer","title":"Encrypted","enum":[1]}]},"accesspoint":{"title":"Access points","description":"List of access points. Connects to the first available AP in list.","type":"array","maxItems":4,"items":{"type":"object","properties":{"ssid":{"title":"SSID","description":"Access point SSID (name of access point)","type":"string","pattern":"^(?!\\s).+(?<!\\s)$","minLength":0,"maxLength":32},"pwd":{"title":"Password","type":"string","pattern":"^(?!\\s).+(?<!\\s)$","default":"","maxLength":64},"minrssi":{"title":"Minimum RSSI (received signal strength indicator), 0-100%","description":"Sets a minimum required access point signal strength. The device will not connect to the access point if the measured signal strength is below the value of this field.","type":"integer","default":0,"minimum":0,"maximum":100}},"additionalProperties":false,"required":["ssid","pwd","minrssi"]}}},"dependencies":{"keyformat":{"oneOf":[{"properties":{"keyformat":{"enum":[0]},"accesspoint":{"items":{"type":"object","properties":{"pwd":{"title":"Password","description":"Access point password in plain form (max 64). Leave empty to connect to an open AP. Example: 31aAabC81@99.","pattern":"^[ -~]*$","minLength":0}}}}}},{"properties":{"keyformat":{"enum":[1]},"accesspoint":{"items":{"type":"object","properties":{"pwd":{"title":"Encrypted password","description":"Access point password in encrypted form (min 24, max 64). Example: rl8/EAy3qTChCsMIIeZPR6rvGEanRJCnL2xbzqo=. IMPORTANT: Ensure that you encrypt all access point passwords and that you include the server public key","pattern":"^[a-zA-Z0-9+/=]*$","minLength":24}}}}}}]}},"additionalProperties":false,"required":["mode","keyformat"]},"s3":{"title":"S3 server settings","type":"object","properties":{"sync":{"title":"Synchronization","description":"This section configures how and when the device communicates with the S3 server.","type":"object","properties":{"ota":{"title":"Firmware, config and certificate","description":"Configures how often the device looks for firmware-, config- and certificate-over-the-air updates. Small values may reduce performance. Time period may sometimes become longer if device is busy. Set to 0 to disable.","type":"integer","default":600,"minimum":0,"maximum":86400,"multipleOf":5},"heartbeat":{"title":"Heartbeat","description":"Configures how often the device transmits the heartbeat signal. Small values may reduce performance. Time period may sometimes become longer if device is busy. Set to 0 to disable.","type":"integer","default":300,"minimum":0,"maximum":86400,"multipleOf":5},"logfiles":{"title":"Log files","description":"Configures if the device pushes closed log files to the server. The log files are deleted from the device when successfully uploaded.","type":"integer","default":1,"oneOf":[{"type":"integer","title":"Disable","enum":[0]},{"type":"integer","title":"Enable","enum":[1]}]}},"additionalProperties":false,"required":["ota","heartbeat","logfiles"]},"server":{"title":"Server","description":"This section contains the server connection parameters.","type":"object","properties":{"endpoint":{"title":"Endpoint","description":"S3 server endpoint. Prefix with http:// to connect using standard http. Prefix with https:// to connect using SSL/TLS - requires support by the server and that the server certificate is loaded onto the device. Examples: http://192.168.0.1, https://s3.mydomain.com, https://s3.amazonaws.com, http://s3-us-east-2.amazonaws.com.","type":"string","pattern":"^https*://[a-zA-Z0-9_/\\.-]+$","maxLength":128},"port":{"title":"Port","description":"S3 server port. Examples: 80 (http), 443 (https), 9000 (custom).","type":"integer","minimum":0,"maximum":65535},"bucket":{"title":"Bucket name","description":"S3 server bucket name. Examples: logbucket, fleetbucket, testbucket.","type":"string","pattern":"^[a-z0-9]{1}[a-z0-9\\.\\-]{0,62}[a-z0-9]{1}$","maxLength":64},"region":{"title":"Region","description":"S3 server region. Example: us-east-1.","type":"string","pattern":"^[a-z0-9-]*$","minLength":0,"maxLength":32},"request_style":{"title":"Request style","description":"Virtual-hosted-style or path-style S3 requests. Virtual hosted-style format: \"http://[BUCKET-NAME].[DOMAIN]/[OBJECT-NAME]\". Path-style format: \"http://[DOMAIN]/[BUCKET-NAME]/[OBJECT-NAME]\"","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Path-style","enum":[0]},{"type":"integer","title":"Virtual hosted-style","enum":[1]}]},"accesskey":{"title":"AccessKey","description":"S3 server access key ID. Example: PRDDKN8R6PAAOGTEI53E","type":"string","pattern":"^[a-zA-Z0-9_-]+$","minLength":3,"maxLength":128},"keyformat":{"title":"SecretKey format","description":"The format of the secret key. Can be used to hide the secret key stored on the device.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Plain","enum":[0]},{"type":"integer","title":"Encrypted","enum":[1]}]},"secretkey":{"title":"SecretKey","type":"string"},"signed_payload":{"title":"Signed payload","description":"Include payload checksum in signature. Reduces device upload performance.","type":"integer","default":0,"oneOf":[{"type":"integer","title":"Off","enum":[0]},{"type":"integer","title":"On","enum":[1]}]}},"dependencies":{"endpoint":["port","bucket","region","request_style","accesskey","keyformat","secretkey","signed_payload"],"keyformat":{"oneOf":[{"properties":{"keyformat":{"enum":[0]},"secretkey":{"description":"S3 server secret key in plain form (max 128). Example: IAkwE9vvEh9ke4RH","pattern":"^[ -~]*$","minLength":1,"maxLength":128}}},{"properties":{"keyformat":{"enum":[1]},"secretkey":{"description":"S3 server secret key in encrypted form (min 24, max 150). Example: AKGaqGJWxEhTfJX6oeR/OIdu5Swm9HQY. IMPORTANT: Ensure that you correctly encrypt the secretKey and that you include the server public key","pattern":"^[a-zA-Z0-9+/=]*$","minLength":24,"maxLength":150}}}]}},"additionalProperties":false}},"additionalProperties":false}},"additionalProperties":false,"required":["wifi"]}},"additionalProperties":false,"required":["general","log","rtc","secondaryport","can_internal","can_1","can_2","lin_1","lin_2"]},"uiSchema":{},"theme":"default","liveSettings":{"showErrorList":"top","validate":false,"disabled":false,"noHtml5Validate":true,"readonly":false,"omitExtraData":true,"liveOmit":true,"experimental_defaultFormStateBehavior":{"arrayMinItems":"populate","emptyObjectFields":"populateAllDefaults"}}}

xyy7260 commented 1 year ago

@MatinF Did you solve it?

MatinF commented 1 year ago

No in contrast, the latest rjsf playground exhibits performance issues for all fields when we load our Schema. This is not the case in the older versions as discussed in this thread and in the latest rjsf version it seems the issue of performance is no longer limited to array entries.

You should be able to replicate this performance issue by using the playground link I added in my previous post.

xyy7260 commented 1 year ago

@MatinF Ok, I wonder if the next release will fix the performance issues

heath-freenome commented 1 year ago

@MatinF I'm using your playground link and when I turn off omit extra data and live omit the response time goes from a second or 2 delay to about 1/4 of a second. Maybe it make sense to add some performance tuning optional parameters to the Form. If you want live omit, maybe we can add a skipOneOf or skipArrays flags to return things to where they were before the bug fix. Also, maybe there is a more performant way of omitting live data that doesn't rely on the pathSchema? All of these things require time and a lot of debugging, which sadly, I do not have much of in the 2 hours a week I am able to spend on the library.

MatinF commented 1 year ago

Thanks for providing inputs - fully understand that there is limited time for this. For now, we're using the older version which works OK for us right now, so this is more a focus for longer-term as we'd of course want to be able to keep up with new features/improvements eventually.

I tried testing with the live omit and omit extra data turned off and it does improve it a bit - but if you e.g. write some text in the top, it still seems very laggy on my end compared to the older versions. I'm not sure what is causing that, however.