サイラスSASLとEXTERNALメカニズムを使用して
-
22-08-2019 - |
質問
サイラスSASL APIは、外部機構をサポートしていませんか?私がしようとしています
クライアントとしてそれを使用しますが、尋ねられたとき、それはSASL_NOMECH
を返します。
% cat cyrus_sal_ex.c
/* cyrus_sasl_ex.c: Example of using the Cyrus SASL api */
#include <stdio.h> /* for printf() */
#include <sasl/sasl.h> /* for sasl_client_*(), SASL_*, sasl_*_t */
static char const * SASL_return_code(int const code)
{
switch(code)
{
/* ... */
case SASL_OK: return "SASL_OK[0]: successful result";
/* ... */
case SASL_NOMECH: return "SASL_NOMECH[-4]: mechanism not supported";
/* ... */
}
return "unrecognized";
}
int main()
{
char const * output = NULL;
unsigned outlen = 0;
char const * mechanism = NULL;
sasl_conn_t * conn;
# define PRINT_RESULT( x ) do\
{\
int const __result = (x);\
printf("%s == %d\n\t%s\n", #x, __result, SASL_return_code(__result));\
if (__result < 0) goto done;\
}\
while (0)
PRINT_RESULT( sasl_client_init( NULL ) );
PRINT_RESULT( sasl_client_new( "fake", "fakey.mcfaker.ton", "127.0.0.1", "127.255.255.1", NULL, 0, &conn) );
PRINT_RESULT( sasl_client_start( conn, "EXTERNAL", NULL, &output, &outlen, &mechanism) );
done:
# undef PRINT_RESULT
printf("output: [%d bytes] : %s\n", outlen, (output ? output : "NULL") );
printf("mechanism: %s\n", (mechanism ? mechanism : "NULL"));
return 0;
}
% gcc -I/sw/include -L/sw/lib -lsasl2 cyrus_sasl_ex.c -o cyrus_sasl_ex # your header/library locations may vary
% ./cyrus_sasl_ex
sasl_client_init( NULL ) == 0
SASL_OK[0]: successful result
sasl_client_new( "fake", "fakey.mcfaker.ton", "127.0.0.1", "127.255.255.1", NULL, 0, &conn) == 0
SASL_OK[0]: successful result
sasl_client_start( conn, "EXTERNAL", NULL, &output, &outlen, &mechanism) == -4
SASL_NOMECH[-4]: mechanism not supported
output: [0 bytes] : NULL
mechanism: EXTERNAL
%
私はしかしソースを通過閲覧、そしてそれは次のようになりますすべてのクライアントが外部メカニズムをサポートする必要があります:
cyrus-sasl-2.1.22/lib/client.c:
196 int sasl_client_init(const sasl_callback_t *callbacks)
197 {
...
227
228 sasl_client_add_plugin("EXTERNAL", &external_client_plug_init);
229
だから私は、私はここで何か間違ったことをやっている推測しています。私はsasl_callback_t
に考えることができるすべてsasl_client_*()
sを追加しようとしたが、
それらのどれにも呼び出されないました。 EXTERNALが許容できるメカニズムであることを主張する私は渡す必要があり、いくつかの引数がありますか?
またはSASL_NOMECHは常に外部に返される - 。右のようではありませんB / C
誰も私を助けることはできますか?
解決
[OK]を、私は取り残さステップを発見します。
sasl/sasl.h
によると、私はSASL_AUTH_EXTERNAL
プロパティを設定するために必要な
sasl_conn_t
用
/* set property in SASL connection state
* returns:
* SASL_OK -- value set
* SASL_BADPARAM -- invalid property or value
*/
LIBSASL_API int sasl_setprop(sasl_conn_t *conn,
int propnum,
const void *value);
#define SASL_SSF_EXTERNAL 100 /* external SSF active (sasl_ssf_t *) */
#define SASL_SEC_PROPS 101 /* sasl_security_properties_t */
#define SASL_AUTH_EXTERNAL 102 /* external authentication ID (const char *) */
/* If the SASL_AUTH_EXTERNAL value is non-NULL, then a special version of the
* EXTERNAL mechanism is enabled (one for server-embedded EXTERNAL mechanisms).
* Otherwise, the EXTERNAL mechanism will be absent unless a plug-in
* including EXTERNAL is present.
*/
私はそれをした後は、残りの部分は働います:
% cat cyrus_sasl_ex.c
/* Example of using the Cyrus SASL api */
#include <stdio.h> /* for printf() */
#include <sasl/sasl.h> /* for sasl_client_*(), SASL_*, sasl_*_t */
int main()
{
char const * output = NULL;
unsigned outlen = 0;
char const * mechanism = NULL;
sasl_conn_t * conn;
# define PRINT_RESULT( x ) do\
{\
int const __result = (x);\
printf("%s == %d\n\t%s\n", #x, __result, sasl_errstring(__result,NULL,NULL));\
if (__result < 0) goto done;\
}\
while (0)
PRINT_RESULT( sasl_client_init( NULL ) );
PRINT_RESULT( sasl_client_new( "fake", "fakey.mcfaker.ton", "127.0.0.1", "127.255.255.1", NULL, 0, &conn) );
PRINT_RESULT( sasl_setprop( conn, SASL_AUTH_EXTERNAL, "fake authority" ) );
PRINT_RESULT( sasl_client_start( conn, "EXTERNAL", NULL, &output, &outlen, &mechanism) );
done:
# undef PRINT_RESULT
printf("output: [%d bytes] : %s\n", outlen, (output ? output : "NULL") );
printf("mechanism: %s\n", (mechanism ? mechanism : "NULL"));
return 0;
}
% gcc -I/sw/include -L/sw/lib -lsasl2 cyrus_sasl_ex.c -o cyrus_sasl_ex
% ./cyrus_sasl_ex
sasl_client_init( NULL ) == 0
successful result
sasl_client_new( "fake", "fakey.mcfaker.ton", "127.0.0.1", "127.255.255.1", NULL, 0, &conn) == 0
successful result
sasl_setprop( conn, SASL_AUTH_EXTERNAL, "fake authority" ) == 0
successful result
sasl_client_start( conn, "EXTERNAL", NULL, &output, &outlen, &mechanism) == 0
successful result
output: [0 bytes] :
mechanism: EXTERNAL
しかし、OS X 10.5にプリインストールされていますサイラスSASLのバージョンは、その戻り値を格納するための外部プラグインはSASL_CB_USER
コールバックを必要となり、それにNULLポインタを渡すことで、バグ、この静止手段を有しているので、私は、これらすべてのマシン上でのCyrus SASLを更新する必要があります。
それとも私はちょうどバグを回避してコードでしょう。
他のヒント
これは、CyrusのSASLが無いメカニズム(これらは動的にデフォルトでリンクされているものとする)でコンパイルされたことに起因します。そのため、動的にリンクされたメカニズムが存在しない場合には、一致するメカニズムが存在しないことを報告します。
そのため、より良い答えが静的にリンクされた(サイラス・パッケージにプラグインと呼ばれる)メカニズムとサイラスSASLを再コンパイルすることです。あなたはconfig.hのヘッダを見て、1に対応する静的定義を#defineする場合、再コンパイル(私は、手動でプラグインディレクトリからlibsasl2.aアーカイブにプラグインソースを追加)。あなたはこのライブラリをリンクするとき、あなたは文句を言わない(あなたが見つけ回避策なし)そのエラーを取得します。