summaryrefslogtreecommitdiff
path: root/doc/en
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2020-02-29 21:02:42 +0100
committerSébastien Helleu <flashcode@flashtux.org>2020-02-29 21:02:42 +0100
commit410a5b341f4b6246fcebdeab18251f85f3f1bda7 (patch)
treef8ca616cab500daad8efd149aa87d0f513b39b25 /doc/en
parent7e808e2ef7e3e6eee0027502d8670157bd4983f9 (diff)
downloadweechat-410a5b341f4b6246fcebdeab18251f85f3f1bda7.zip
api: add functions string_hash_binary and string_hash
Diffstat (limited to 'doc/en')
-rw-r--r--doc/en/weechat_plugin_api.en.adoc110
1 files changed, 110 insertions, 0 deletions
diff --git a/doc/en/weechat_plugin_api.en.adoc b/doc/en/weechat_plugin_api.en.adoc
index 429032e62..622cef607 100644
--- a/doc/en/weechat_plugin_api.en.adoc
+++ b/doc/en/weechat_plugin_api.en.adoc
@@ -2061,6 +2061,116 @@ char *dump = weechat_string_hex_dump (string, strlen (string), 8, " >> ", NULL);
[NOTE]
This function is not available in scripting API.
+==== string_hash_binary
+
+_WeeChat ≥ 2.8._
+
+Compute hash of data.
+
+Prototype:
+
+[source,C]
+----
+void string_hash_binary (const char *data, int length_data, const char *hash_algo,
+ char **hash, int *length_hash);
+----
+
+Arguments:
+
+* _data_: the data to hash
+* _length_data_: number of bytes to hash in _data_
+* _hash_algo_: the hash algorithm, see table below
+* _hash_: pointer to the hash variable, which is allocated by the function and
+ used to store the resulting hash (NULL if error)
+* _length_hash_: pointer to a variable used to store the length of the hash
+ computed (in bytes) (0 if error)
+
+Supported hash algorithms:
+
+[width="100%",cols="4,4,4,5,12",options="header"]
+|===
+| Value | Algorithm | Hash size | Output (binary) | Notes
+| `+md5+` | MD5 | 128 bits | 16 bytes | *Weak*, not recommended for cryptography usage.
+| `+sha1+` | SHA-1 | 160 bits | 20 bytes | *Weak*, not recommended for cryptography usage.
+| `+sha224+` | SHA-224 | 224 bits | 28 bytes |
+| `+sha256+` | SHA-256 | 256 bits | 32 bytes |
+| `+sha384+` | SHA-384 | 384 bits | 48 bytes |
+| `+sha512+` | SHA-512 | 512 bits | 64 bytes |
+| `+sha3-224+` | SHA3-224 | 224 bits | 28 bytes |
+| `+sha3-256+` | SHA3-256 | 256 bits | 32 bytes |
+| `+sha3-384+` | SHA3-384 | 384 bits | 48 bytes |
+| `+sha3-512+` | SHA3-512 | 512 bits | 64 bytes |
+|===
+
+C example:
+
+[source,C]
+----
+const char *data = "abcdefghijklmnopqrstuvwxyz";
+char *hash;
+int length_hash;
+weechat_string_hash_binary (data, strlen (data), "sha256", &hash, &length_hash);
+/* hash is a binary buffer with:
+ 71 c4 80 df 93 d6 ae 2f 1e fa d1 44 7c 66 c9 52 5e 31 62 18 cf 51 fc 8d 9e d8 32 f2 da f1 8b 73 */
+----
+
+[NOTE]
+This function is not available in scripting API.
+
+==== string_hash
+
+_WeeChat ≥ 2.8._
+
+Compute hash of data, as hexadecimal string.
+
+Prototype:
+
+[source,C]
+----
+char *string_hash (const char *data, int length_data, const char *hash_algo);
+----
+
+Arguments:
+
+* _data_: the data to hash
+* _length_data_: number of bytes to hash in _data_
+* _hash_algo_: the hash algorithm, see table below
+
+Supported hash algorithms:
+
+[width="100%",cols="4,4,4,5,12",options="header"]
+|===
+| Value | Algorithm | Hash size | Output (string) | Notes
+| `+md5+` | MD5 | 128 bits | 32 hex chars | *Weak*, not recommended for cryptography usage.
+| `+sha1+` | SHA-1 | 160 bits | 40 hex chars | *Weak*, not recommended for cryptography usage.
+| `+sha224+` | SHA-224 | 224 bits | 56 hex chars |
+| `+sha256+` | SHA-256 | 256 bits | 64 hex chars |
+| `+sha384+` | SHA-384 | 384 bits | 96 hex chars |
+| `+sha512+` | SHA-512 | 512 bits | 128 hex chars |
+| `+sha3-224+` | SHA3-224 | 224 bits | 56 hex chars |
+| `+sha3-256+` | SHA3-256 | 256 bits | 64 hex chars |
+| `+sha3-384+` | SHA3-384 | 384 bits | 96 hex chars |
+| `+sha3-512+` | SHA3-512 | 512 bits | 128 hex chars |
+|===
+
+Return value:
+
+* string with hash of data as hexadecimal (must be freed by calling "free"
+ after use), NULL if error
+
+C example:
+
+[source,C]
+----
+const char *data = "abcdefghijklmnopqrstuvwxyz";
+char *hash;
+hash = weechat_string_hash (data, strlen (data), "sha256");
+/* hash == "71c480df93d6ae2f1efad1447c66c9525e316218cf51fc8d9ed832f2daf18b73"
+----
+
+[NOTE]
+This function is not available in scripting API.
+
==== string_is_command_char
_WeeChat ≥ 0.3.2._