auth.h 1.71 KB
Newer Older
1 2 3 4 5 6 7
/*
 * Copyright (C) the libgit2 contributors. All rights reserved.
 *
 * This file is part of libgit2, distributed under the GNU GPL v2 with
 * a Linking Exception. For full terms see the included COPYING file.
 */

8 9
#ifndef INCLUDE_transports_auth_h__
#define INCLUDE_transports_auth_h__
10

11
#include "common.h"
12
#include "net.h"
13 14

typedef enum {
15 16
	GIT_HTTP_AUTH_BASIC = 1,
	GIT_HTTP_AUTH_NEGOTIATE = 2,
17
	GIT_HTTP_AUTH_NTLM = 4
18
} git_http_auth_t;
19 20 21 22 23

typedef struct git_http_auth_context git_http_auth_context;

struct git_http_auth_context {
	/** Type of scheme */
24
	git_http_auth_t type;
25 26

	/** Supported credentials */
27
	git_credential_t credtypes;
28 29 30

	/** Connection affinity or request affinity */
	unsigned connection_affinity : 1;
31 32 33 34 35

	/** Sets the challenge on the authentication context */
	int (*set_challenge)(git_http_auth_context *ctx, const char *challenge);

	/** Gets the next authentication token from the context */
36
	int (*next_token)(git_str *out, git_http_auth_context *ctx, git_credential *cred);
37

38 39 40
	/** Examines if all tokens have been presented. */
	int (*is_complete)(git_http_auth_context *ctx);

41 42 43 44 45 46
	/** Frees the authentication context */
	void (*free)(git_http_auth_context *ctx);
};

typedef struct {
	/** Type of scheme */
47
	git_http_auth_t type;
48 49 50 51 52

	/** Name of the scheme (as used in the Authorization header) */
	const char *name;

	/** Credential types this scheme supports */
53
	git_credential_t credtypes;
54 55 56 57

	/** Function to initialize an authentication context */
	int (*init_context)(
		git_http_auth_context **out,
58
		const git_net_url *url);
59 60 61 62
} git_http_auth_scheme;

int git_http_auth_dummy(
	git_http_auth_context **out,
63
	const git_net_url *url);
64 65 66

int git_http_auth_basic(
	git_http_auth_context **out,
67
	const git_net_url *url);
68 69

#endif