1 // -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*-
2 // vim: ts=8 sw=2 smarttab
4 * Ceph - scalable distributed file system
6 * Copyright (C) 2015 New Dream Network
8 * This is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License version 2.1, as published by the Free Software
11 * Foundation. See file COPYING.
22 #include "rgw/rgw_ldap.h"
23 #include "rgw/rgw_token.h"
25 #include "gtest/gtest.h"
26 #include "common/ceph_argparse.h"
27 #include "common/debug.h"
28 #include "global/global_init.h"
30 #define dout_subsys ceph_subsys_rgw
39 bool do_hexdump = false;
41 string access_key("ewogICAgIlJHV19UT0tFTiI6IHsKICAgICAgICAidmVyc2lvbiI6IDEsCiAgICAgICAgInR5cGUiOiAibGRhcCIsCiAgICAgICAgImlkIjogImFkbWluIiwKICAgICAgICAia2V5IjogImxpbnV4Ym94IgogICAgfQp9Cg=="); // {admin,linuxbox}
42 string other_key("ewogICAgIlJHV19UT0tFTiI6IHsKICAgICAgICAidmVyc2lvbiI6IDEsCiAgICAgICAgInR5cGUiOiAibGRhcCIsCiAgICAgICAgImlkIjogImFkbWluIiwKICAgICAgICAia2V5IjogImJhZHBhc3MiCiAgICB9Cn0K"); // {admin,badpass}
44 string ldap_uri = "ldaps://f23-kdc.rgw.com";
45 string ldap_binddn = "uid=admin,cn=users,cn=accounts,dc=rgw,dc=com";
46 string ldap_bindpw = "supersecret";
47 string ldap_searchdn = "cn=users,cn=accounts,dc=rgw,dc=com";
48 string ldap_searchfilter = "";
49 string ldap_dnattr = "uid";
51 rgw::LDAPHelper ldh(ldap_uri, ldap_binddn, ldap_bindpw, ldap_searchdn,
52 ldap_searchfilter, ldap_dnattr);
56 TEST(RGW_LDAP, INIT) {
61 TEST(RGW_LDAP, BIND) {
66 TEST(RGW_LDAP, AUTH) {
71 RGWToken token{from_base64(access_key)};
72 ret = ldh.auth(token.id, token.key);
76 RGWToken token{from_base64(other_key)};
77 ret = ldh.auth(token.id, token.key);
82 TEST(RGW_LDAP, SHUTDOWN) {
86 int main(int argc, char *argv[])
89 vector<const char*> args;
91 argv_to_vec(argc, const_cast<const char**>(argv), args);
94 for (auto arg_iter = args.begin(); arg_iter != args.end();) {
95 if (ceph_argparse_witharg(args, arg_iter, &val, "--access",
98 } else if (ceph_argparse_flag(args, arg_iter, "--hexdump",
106 /* dont accidentally run as anonymous */
107 if (access_key == "") {
108 std::cout << argv[0] << " no AWS credentials, exiting" << std::endl;
112 saved_args.argc = argc;
113 saved_args.argv = argv;
115 ::testing::InitGoogleTest(&argc, argv);
116 return RUN_ALL_TESTS();