API-dokumentation

Allmänt

Vi har ett standard REST API för att hantera hemligheter. Alla förfrågningar och svar använder JSON format.

Du kan använda API:et för att hantera både kryptering och dekryptering av hemligheten utanför vår tjänst, utan att behöva ladda några tillgångar från oss. Det tillåter också dig att använda vilken typ av leveransmetod som helst för den publika lösenordsdelen (halva lösenordet som används för att härleda krypteringsnyckeln för hemligheten från) och i princip skapa vilken typ av anpassad konfiguration som helst för att visa hemligheten.

Kodexempel

Vänligen se våra API-exempel om hur man använder API:et.

Autentisering

Vi använder två typer av API-nycklar för autentisering:

  • Publika API-nycklar
  • Privata API-nycklar

Publika API-nycklar är avsedda för att skapa en anpassad själv-hostad sida för visning av hemlighet. Alla andra API-åtgärder kräver en privat API-nyckel.

Publika API-nycklar kan användas i offentliga skript. Privata API-nycklar måste alltid hållas privata.

Båda API-nycklarna innehåller typ av nyckel i själva nyckeln så att de lätt kan särskiljas.

API-nyckeln måste skickas i Authorization: ApiKey <key> header, såsom:

Authorization: ApiKey public_key_abc...

Fel

Vid misslyckad förfrågan kommer svaret att ha ett error objekt.

Objektet innehåller följande fält:

  • message: det fullständiga felmeddelandet, t.ex. "Ciphertext kan inte vara tom"
  • field: fältet som felet gäller, t.ex. "ciphertext"

HTTP-svarsstatuskoden kommer också att indikera ett fel, till exempel:

  • 403 Förbjudet: förfrågan tilläts inte, till exempel på grund av ogiltig API-nyckel
  • 404 Hittades inte: den begärda hemligheten hittades inte

Visa hemlighet

Förfrågningstyp: GET

Förfrågningssökväg: https://password.link/api/secrets/<id>

Statuskod för lyckad förfrågan: 200 OK


Hämta chiffertexten, privata lösenordsdelen och andra detaljer om en hemlighet. Kräver publik API-nyckel.

Denna API-förfrågan kan användas för att skapa en anpassad själv-hostad sida för visning av hemlighet som inte laddar några skript eller andra tillgångar från vår tjänst.

Att framgångsrikt hämta en hemlighet markerar den automatiskt som visad och raderar därmed chiffertexten och den privata lösenordsdelen från vår databas, vilket gör det omöjligt att visa hemligheten igen.

Obligatoriska parametrar
  • id: id för hemligheten, till exempel dT5g

Exempel på fråga

curl -H "Authorization: ApiKey public_key_abcd" https://password.link/api/secrets/dT5g

Exempel på svar

{
        "data": {
          "id": "iD för den hemliga informationen",
          "ciphertext": "chiffertexten för hemligheten",
          "password_part_private": "den privata lösenordsdelen av hemligheten",
          "message": "meddelandet för hemligheten, om angivet"
        },
        "metadata": {
          "secrets_total": 1,
          "secrets_usage": 1,
          "secrets_allowance": 1
        }
      }

Kodexempel

Vänligen se våra API-exempel.

Skapa hemlighet

Förfrågningstyp: POST

Förfrågningssökväg: https://password.link/api/secrets

Statuskod för lyckad förfrågan: 201 Created

Detta API-anrop stöder också att lägga till en bilaga till hemligheten. Vänligen kontakta oss för mer information.


Skapa en krypterad hemlighet.

Att kryptera hemligheten på klientsidan innan den skickas till vårt API kräver att en SJCL-kompatibel chiffertext JSON-sträng skapas. Vänligen se <a href=\"https://github.com/bitwiseshiftleft/sjcl\">SJCL-dokumentation</a> för korrekt format av JSON-strängen, och se våra <a href=\"/p/docs/api/examples\">Exempel på API</a> för exempel på hur man skapar chiffertexten.

Skapa lösenordet för att kryptera hemligheten

Lösenordet som används för att kryptera hemligheten i AES måste bestå av två 18 tecken långa strängar. Den faktiska krypteringsnyckeln kommer att vara sammanfogningen av dessa två strängar ("privat del" + "publik del") och härleds från lösenordet av SJCL med PBKDF2.

Exempel på att skapa de privata och publika lösenordsdelarna:

Password: fkgjbnvlakwiejgutnFIGKEOTIRUBNAKQJRL
        => Private part: fkgjbnvlakwiejgutn
        => Public part: FIGKEOTIRUBNAKQJRL

Den privata delen måste vara Base64-kodad innan den skickas till vårt API. Om du använder sidan för visning av hemlighet som tillhandahålls av oss måste du också Base64-koda den publika delen. Om du använder en själv-hostad sida för visning av hemlighet kan du använda samma metod eller skapa din egen. Vänligen se våra <a href=\"/p/docs/api/examples\">Exempel på API</a> för referensimplementationer.

Obligatoriska SJCL AES-inställningar

Du måste använda följande inställningar för AES när du krypterar hemligheten:

  • Läge: AES-GCM (SJCL-inställning: "mode:gcm")
  • Nyckelstorlek: 256 bits (SJCL-inställning: "ks:256")
  • Nyckel härledningsfunktion: PBKDF2 (SJCL standard)
  • PBKDF2-iterationer: 10000 (SJCL-inställning: "iter:10000")

Förfrågningsdata

{
        "ciphertext": "ciphertext",
        "password_part_private": "password_part_private",
        "description": "description",
        "message": "message",
        "expiration": "expiration",
        "view_button": "view_button",
        "captcha": "captcha",
        "password": "password",
        "max_views": "max_views"
      }

Parametrar för begäran

  • ciphertext: En SJCL-kompatibel chiffertext JSON-sträng av hemligheten, kodad i Base64.
  • password_part_private: den privata lösenordsdelen som användes för att kryptera hemligheten, i Base64.
  • description (valfri): en beskrivning för hemligheten. Kan inte ses när hemligheten visas.
  • message (valfri): ett meddelande för hemligheten. Visas tillsammans med hemligheten.
  • expiration (valfri): en utgångstid för hemligheten, i timmar. Möjliga värden: 0-350.
  • view_button (valfri): visa en knapp för att visa hemlighet istället för att visa hemligheten omedelbart efter att länken öppnats. För att aktivera denna funktion, ställ in detta till true.
  • captcha (valfri): visa en enkel CAPTCHA innan hemligheten visas, huvudsakligen för att blockera automatiserade skannrar. För att aktivera denna funktion, ställ in detta till true.
  • password (valfri): ett lösenord för hemligheten.
  • max_views (valfri): hur många gånger hemligheten kan ses. Möjliga värden: 1-100.

Kodexempel

Vänligen se våra API-exempel.

Lista hemligheter

Förfrågningstyp: GET

Förfrågningssökväg: https://password.link/api/secrets

Statuskod för lyckad förfrågan: 200 OK


Hämta en lista över hemligheter. Innehåller inte chiffertexternas privata lösenordsdelar, endast ID:n, beskrivningar och liknande.

Limit och offset

Det maximala antalet returnerade hemligheter för varje förfrågan är begränsat till 50. Du kan kontrollera offset med den valfria offset frågeparameter.

Om du t.ex. vill hoppa över de första 50 posterna använder du en fråga som: .../api/secrets?offset=50

Exempel på fråga

curl -H "Authorization: ApiKey private_key_abcd" https://password.link/api/secrets

Exempel på svar

{
        "data": [
          {
            "id": iD för den hemliga informationen,
            "created_at": när hemligheten skapades,
            "message": meddelandet för hemligheten,
            "description": beskrivningen av hemligheten,
            "view_button": är knappen visa hemlighet aktiverad,
            "captcha": är CAPTCHA aktiverad,
            "password": har hemligheten ett lösenord,
            "expiration": utgångstid i timmar,
            "expired": har hemligheten gått ut,
            "view_times": hur många gånger hemligheten har visats,
            "max_views": maximalt antal gånger hemligheten kan ses,
            "views": [
              {
                "viewed_at": en tidsstämpel för när hemligheten visades,
                "viewed_by_ip": IP-adress för visaren,
                "viewed_by_user_agent": användar agent för visaren
              }
            ]
          }
        ],
        "metadata": {
          "secrets_total": 1,
          "secrets_usage": 1,
          "secrets_allowance": 1
        }
      }

Radera hemlighet

Förfrågningstyp: DELETE

Förfrågningssökväg: https://password.link/api/secrets/<id>

Statuskod för lyckad förfrågan: 200 OK


Radera en hemlighet.

Exempel på fråga

curl -H "Authorization: ApiKey private_key_abcd" \\
          -X DELETE https://password.link/api/secrets/dT5g

Exempel på svar

{
        "data": null,
        "metadata": {
          "secrets_total": 1,
          "secrets_usage": 1,
          "secrets_allowance": 1
        }
      }

Skapa hemlig begäran

Typ av begäran: POST

Sökväg för begäran: https://password.link/api/secret_requests

Statuskod för framgångsrik fråga: 201 Created


Skapa en ny hemlig begäran.

Parametrar för begäran

  • description: beskrivning för den hemliga begäran.
  • message: meddelande för Secret Request-tittaren.
  • expiration: utgångstid för den hemliga begäran, i timmar.
  • limit: användningsgräns för den hemliga begäran.
  • send_request_to_email: skicka den skapade länken för hemlig begäran till den angivna e-postadressen.
  • send_to_email: skicka den hemliga länken som skapats med hjälp av den hemliga begäran till den angivna e-postadressen.
  • secret_description: beskrivning för den hemlighet som skapats med hjälp av hemlighetsbegäran.
  • secret_message: meddelande för den hemlighet som skapats med hjälp av hemlighetsbegäran.
  • secret_expiration: utgångstid för hemligheten som skapas med den hemliga förfrågan, i timmar.utgångstid i timmar för den hemlighet som skapats med hjälp av hemlighetsbegäran.
  • secret_password: lösenord för hemligheten som skapas med den hemliga förfrågan, i timmar.lösenord för den hemlighet som skapats med hjälp av hemlighetsbegäran, i timmar.
  • secret_max_views: visningsgräns för den hemlighet som skapats med hjälp av hemlighetsbegäran.

Exempel på fråga

curl -H "Authorization: ApiKey private_key_abcd" \
        -H "Content-Type: application/json" -X POST https://password.link/api/secret_requests

Exempel på svar

{
        "data": {
          "id":"5e976e6e-d205-4f58-8df9-5ac0048bc702"
        },
        "metadata": {
          "secrets_total":70,
          "secrets_usage":25,
          "secrets_allowance":100,
          "secret_requests_total":10,
          "secret_requests_allowance":100
        }
      }

Lista hemliga förfrågningar

Typ av begäran: GET

Sökväg för begäran: https://password.link/api/secret_requests

Statuskod för framgångsrik fråga: 200 OK


Limit och offset

Det maximala antalet returnerade resultat för varje förfrågan är begränsat till 50. Du kan kontrollera offset med den valfria offset-frågeparametern.

Om du t.ex. vill hoppa över de första 50 posterna använder du en fråga som: .../api/secret_requests?offset=50

Exempel på fråga

curl -H "Authorization: ApiKey private_key_abcd" https://password.link/api/secret_requests

Exempel på svar

{
        "data":[
          {
            "id":"5e976e6e-d205-4f58-8df9-5ac0048bc702",
            "description":"example",
            "message":"example",
            "expiration":3,
            "limit":1,
            "send_to_email":"example@example.com",
            "secret_description":"example",
            "secret_message":"example",
            "secret_expiration":"example",
            "secret_max_views":4,
            "secret_password":false,
            "template_id":null
          }
        ],
        "metadata": {
          "secrets_total":70,
          "secrets_usage":25,
          "secrets_allowance":100,
          "secret_requests_total":10,
          "secret_requests_allowance":100
        }
      }

Begäran om att ta bort hemlighet

Typ av begäran: DELETE

Sökväg för begäran: https://password.link/api/secret_requests/<id>

Statuskod för framgångsrik fråga: 200 OK


Ta bort en hemlig begäran.

Exempel på fråga

curl -H "Authorization: ApiKey private_key_abcd" \
      -X DELETE https://password.link/api/secret_requests/5e976e6e-d205-4f58-8df9-5ac0048bc702

Exempel på svar

{
        "data": null,
        "metadata": {
          "secrets_total":70,
          "secrets_usage":25,
          "secrets_allowance":100,
          "secret_requests_total":10,
          "secret_requests_allowance":100}
      }