Date shifting

Le date sono un tipo di dati molto comune. Nei casi in cui le date possono essere considerate dati sensibili o informazioni che consentono l'identificazione personale (PII), potrebbe essere necessario generalizzarle, offuscarle o oscurarle.

Un metodo per farlo è la generalizzazione o il raggruppamento. A seconda del caso d'uso e della configurazione, però, il raggruppamento può rimuovere l'utilità nelle date. Ad esempio, se generalizzi tutte le date a un solo anno, potresti perdere l'ordine in cui si verificano gli eventi all'interno di quell'anno. Un metodo alternativo per offuscare le date che risolve questo problema è lo spostamento delle date.

Le tecniche di spostamento delle date spostano in modo casuale un insieme di date, ma conservano la sequenza e la durata di un periodo di tempo. Lo spostamento delle date viene solitamente eseguito in relazione a una persona o a una persona giuridica. ovvero le date di ogni persona vengono spostate di un periodo di tempo univoco per quella persona.

Esempio di spostamento della data

Considera i seguenti dati:

user_id data azione
1 2009-06-09 run
1 2009-06-03 camminata
1 2009-05-23 scansione
2 2010-11-03 scansione
2 2010-11-22 camminata

Se generalizzi queste date all'anno, ottieni:

user_id date_year azione
1 2009 run
1 2009 camminata
1 2009 scansione
2 2010 scansione
2 2010 camminata

Ma ora hai perso qualsiasi senso della sequenza per utente.

Prova invece a spostare le date:

user_id data azione
1 2009-07-17 run
1 2009-07-11 camminata
1 2009-06-30 scansione
2 2011-01-26 scansione
2 2011-02-14 camminata

Nota come le date siano diverse, ma la sequenza e la durata vengono mantenute. L'entità dello spostamento delle date era diversa tra user_id 1 e 2.

Spostamento delle date in Sensitive Data Protection

Un oggetto JSON per configurare questo metodo per content.deidentify di Sensitive Data Protection è il seguente:

deidentify_config {
  record_transformations {
    field_transformations {
      fields {
        name: "date"
      }
      primitive_transformation {
        date_shift_config {
          upper_bound_days: 100
          lower_bound_days: -100
          entity_field_id {
            name: "user_id"
          }
          crypto_key {
            unwrapped {
              key: "123456789012345678901234567890ab"
            }
          }
        }
      }
    }
  }
}

I limiti superiore e inferiore dello spostamento sono specificati rispettivamente dai valori upper_bound_days e lower_bound_days. Il contesto o l'ambito a cui si applicherà il turno si basa sul valore entity_id_field, che in questo caso è "user_id".

Tieni presente anche l'utilizzo di un crypto_key. È simile a come viene utilizzato nella pseudonimizzazione. La chiave ti consentirà di mantenere l'integrità di questi spostamenti di date in più richieste o esecuzioni di dati.

Risorse

Per saperne di più su come anonimizzare i dati utilizzando lo spostamento delle date e altri metodi in Sensitive Data Protection, consulta:

Per informazioni di riferimento sull'API relative alle trasformazioni primitive in Sensitive Data Protection, consulta:

  • DeidentifyConfig object: l'oggetto in cui configurare le opzioni di deidentificazione.
  • PrimitiveTransformations object: Lo spostamento della data è una "trasformazione primitiva" in Sensitive Data Protection.
  • DateShiftConfig object: Object with which to configure the PrimitiveTransformations object. Se specifichi l'oggetto DateShiftConfig, puoi spostare le date di un numero casuale di giorni.