You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

milter.h 4.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. /*
  2. * Copyright 2024 Vsevolod Stakhov
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #ifndef RSPAMD_MILTER_H
  17. #define RSPAMD_MILTER_H
  18. #include "config.h"
  19. #include "fstring.h"
  20. #include "addr.h"
  21. #include "contrib/libucl/ucl.h"
  22. #include "contrib/libev/ev.h"
  23. #include "ref.h"
  24. #ifdef __cplusplus
  25. extern "C" {
  26. #endif
  27. enum rspamd_milter_reply {
  28. RSPAMD_MILTER_ADDRCPT = '+',
  29. RSPAMD_MILTER_DELRCPT = '-',
  30. RSPAMD_MILTER_ACCEPT = 'a',
  31. RSPAMD_MILTER_CONTINUE = 'c',
  32. RSPAMD_MILTER_DISCARD = 'd',
  33. RSPAMD_MILTER_CHGFROM = 'e',
  34. RSPAMD_MILTER_ADDHEADER = 'h',
  35. RSPAMD_MILTER_CHGHEADER = 'm',
  36. RSPAMD_MILTER_INSHEADER = 'i',
  37. RSPAMD_MILTER_REPLBODY = 'b',
  38. RSPAMD_MILTER_REJECT = 'r',
  39. RSPAMD_MILTER_TEMPFAIL = 't',
  40. RSPAMD_MILTER_REPLYCODE = 'y',
  41. RSPAMD_MILTER_OPTNEG = 'O',
  42. RSPAMD_MILTER_PROGRESS = 'p',
  43. RSPAMD_MILTER_QUARANTINE = 'q',
  44. };
  45. struct rspamd_email_address;
  46. struct ev_loop;
  47. struct rspamd_http_message;
  48. struct rspamd_config;
  49. struct rspamd_milter_context {
  50. const char *spam_header;
  51. const char *client_ca_name;
  52. const char *reject_message;
  53. const char *quarantine_message;
  54. const char *tempfail_message;
  55. void *sessions_cache;
  56. struct rspamd_config *cfg;
  57. gboolean discard_on_reject;
  58. gboolean quarantine_on_reject;
  59. };
  60. struct rspamd_milter_session {
  61. GHashTable *macros;
  62. rspamd_inet_addr_t *addr;
  63. struct rspamd_email_address *from;
  64. GPtrArray *rcpts;
  65. rspamd_fstring_t *helo;
  66. rspamd_fstring_t *hostname;
  67. rspamd_fstring_t *message;
  68. void *priv;
  69. ref_entry_t ref;
  70. };
  71. typedef void (*rspamd_milter_finish)(int fd,
  72. struct rspamd_milter_session *session, void *ud);
  73. typedef void (*rspamd_milter_error)(int fd,
  74. struct rspamd_milter_session *session,
  75. void *ud, GError *err);
  76. /**
  77. * Handles socket with milter protocol
  78. * @param fd
  79. * @param finish_cb
  80. * @param error_cb
  81. * @param ud
  82. * @return
  83. */
  84. gboolean rspamd_milter_handle_socket(int fd, ev_tstamp timeout,
  85. rspamd_mempool_t *pool,
  86. struct ev_loop *ev_base, rspamd_milter_finish finish_cb,
  87. rspamd_milter_error error_cb, void *ud);
  88. /**
  89. * Updates userdata for a session, returns previous userdata
  90. * @param session
  91. * @param ud
  92. * @return
  93. */
  94. void *rspamd_milter_update_userdata(struct rspamd_milter_session *session,
  95. void *ud);
  96. /**
  97. * Sets SMTP reply string
  98. * @param session
  99. * @param rcode
  100. * @param xcode
  101. * @param reply
  102. * @return
  103. */
  104. gboolean rspamd_milter_set_reply(struct rspamd_milter_session *session,
  105. rspamd_fstring_t *rcode,
  106. rspamd_fstring_t *xcode,
  107. rspamd_fstring_t *reply);
  108. /**
  109. * Send some action to the MTA
  110. * @param fd
  111. * @param session
  112. * @param act
  113. * @return
  114. */
  115. gboolean rspamd_milter_send_action(struct rspamd_milter_session *session,
  116. enum rspamd_milter_reply act, ...);
  117. /**
  118. * Adds some header
  119. * @param session
  120. * @param name
  121. * @param value
  122. * @return
  123. */
  124. gboolean rspamd_milter_add_header(struct rspamd_milter_session *session,
  125. GString *name, GString *value);
  126. /**
  127. * Removes some header
  128. * @param session
  129. * @param name
  130. * @return
  131. */
  132. gboolean rspamd_milter_del_header(struct rspamd_milter_session *session,
  133. GString *name);
  134. void rspamd_milter_session_unref(struct rspamd_milter_session *session);
  135. struct rspamd_milter_session *rspamd_milter_session_ref(
  136. struct rspamd_milter_session *session);
  137. /**
  138. * Converts milter session to HTTP session that is suitable for Rspamd
  139. * @param session
  140. * @return
  141. */
  142. struct rspamd_http_message *rspamd_milter_to_http(
  143. struct rspamd_milter_session *session);
  144. /**
  145. * Sends task results to the
  146. * @param session
  147. * @param results
  148. */
  149. void rspamd_milter_send_task_results(struct rspamd_milter_session *session,
  150. const ucl_object_t *results,
  151. const char *new_body,
  152. gsize bodylen);
  153. /**
  154. * Init internal milter context
  155. * @param spam_header spam header name (must NOT be NULL)
  156. */
  157. void rspamd_milter_init_library(const struct rspamd_milter_context *ctx);
  158. /**
  159. * Returns pool for a session
  160. * @param session
  161. * @return
  162. */
  163. rspamd_mempool_t *rspamd_milter_get_session_pool(
  164. struct rspamd_milter_session *session);
  165. #ifdef __cplusplus
  166. }
  167. #endif
  168. #endif