LSL Protocol/Restrained Love Open Relay Group/delay

From Second Life Wiki
Jump to navigation Jump to search

delay

STATUS: draft

VERSION: 002

Version 002 implemented in Satomi's MultiRelay HUD 1.02

Possible uses

!x-delay/1800|@remoutfit=force: Will strip the victim in half an hour.

@sendchat=n|!x-delay/600|!release: The victim will be mute in chat for the ten coming minutes.

!x-delay/600|@sendchat=n|!x-delay/600|!release: In ten minutes, the victim will be mute in chat for the next ten minutes.

Syntax and semantics

Commands

  • !x-delay/TIME[/IDENT]: delays the remaining subcommands of the command by TIME seconds. Store the bunch of subcommands in the relay event queue, along with the general identifier of the relay command. Optionally, we can specify the string IDENT and it will be used instead.
  • !x-delayclear[/PATTERN]: clears all commands in the relay event queue which have an identifier with PATTERN as a substring. Clears all delays related to the source if PATTERN is not specified.

Formal key points

  • Timers should be restored on relog/reattach. Remaining delays should be postponed by the amount of time spent offline/detached.
  • Devices with running timers should not be pinged on relog but only when the last of their timers expires if any restriction still remains.
  • !release should clear all timers related to the device. This is a case where @clear and !relase behave differently: @clear clears current RLV restrictions, but the absence of active restrictions does not mean the relay is released: indeed running timers (which are not RLV restrictions) may still exist and restrict the wearer later.
  • obviously, !x-handover, if it is asked that restrictions are transfered, should also transfer all remaining timers to the device control is handed over to.

Informal key points

The potential of surprise of !x-delay is something that should be kept in mind while designing relays. Thus it is recommended that the mere fact of setting a timer be not considered a locking action in the following sense:

  • !x-delay commands should be accepted with no particular auth check, especially if that check involves a question to the wearer (typically: Ask mode). Any interactive steps should occur only when the first (meta-)command that actually does something is about to be executed (i.e. after the timer runs out).
  • If the relay has a feature to list current sources to the wearer, then the fact, for a source, of having a running timer should not be a sufficient reason for being listed.
  • Having a running timer also should not be a sufficient reason to make the relay undetachable.

However, for the two following points, a source with only timers should not be ignored:

  • Safewords, if we consider them as user triggered !release, should also clear timers.
  • A source with timers is, in some way, in the relay's directory and informations relative to that source and used by x-tensions such as email, http-in, channel, ack should also be stored and kept up-to-date when possible).

Remark: with respect to the definition of locking action in ORG core requirements: and what it implies in that document, it does not change anything whether we consider that setting a timer is a locking action or not.

However, in the light of the present document, it should be considered locking where !release, !x-handover, safewords and directories are concerned, but not locking where visible effects are concerned (auth dialog/ask mode, listability, undetachability). This calls for two distinct definitions for known source and locking source. Maybe ORG core requirements should be updated to reflect this distinction.


realdelay

STATUS:proposal

VERSION: 002

not implemented

!x-realdelay/!x-realdelayclear should behave exactly the same as !x-delay/!x-delayclear, except that timers are related to RL time. That is timers still run while the wearer is offline.

On relog, every expired timer should be executed, respecting the order (but not the delays, of course). Other timers continue running with no adjustment needed (since the offline time counts in the timer).