| Index: ios/chrome/browser/passwords/js_password_manager.h
|
| diff --git a/ios/chrome/browser/passwords/js_password_manager.h b/ios/chrome/browser/passwords/js_password_manager.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..260ae2e3118bcb5d6c92a330803702efa7154448
|
| --- /dev/null
|
| +++ b/ios/chrome/browser/passwords/js_password_manager.h
|
| @@ -0,0 +1,65 @@
|
| +// Copyright 2012 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef IOS_CHROME_BROWSER_PASSWORDS_JS_PASSWORD_MANAGER_H_
|
| +#define IOS_CHROME_BROWSER_PASSWORDS_JS_PASSWORD_MANAGER_H_
|
| +
|
| +#include "base/ios/block_types.h"
|
| +#import "ios/web/public/web_state/js/crw_js_injection_manager.h"
|
| +
|
| +@class CRWJSInjectionReceiver;
|
| +
|
| +// Loads the JavaScript file, password_controller.js, which contains password
|
| +// form parsing and autofill functions. It will be evaluated on a page that
|
| +// is known to have at least one password form (see hasPasswordForms in
|
| +// core.js.) It returns contents of those password forms and also
|
| +// registers functions that are later used to autofill them.
|
| +@interface JsPasswordManager : CRWJSInjectionManager
|
| +
|
| +// Finds any password forms on the web page.
|
| +// |completionHandler| is then called with the JSON string result (which can
|
| +// be a zero-length string if there was an error). |completionHandler| cannot be
|
| +// nil.
|
| +// For example the JSON string for a form with a single password field is:
|
| +// [{"action":null,"method":null,"usernameElement":"","usernameValue":"","
|
| +// passwords":[{"element":"","value":"asd"}]}]
|
| +- (void)findPasswordFormsWithCompletionHandler:
|
| + (void (^)(NSString*))completionHandler;
|
| +
|
| +// Extracts the password form with the given name from a web page.
|
| +// |completionHandler| is called with the JSON string containing the info about
|
| +// submitted password forms from a web page (it can be zero-length if there was
|
| +// an error). |completionHandler| cannot be nil.
|
| +// For example. the JSON string for a form with a single password field is:
|
| +// {"action":null,"method":null,"usernameElement":"","usernameValue":"",
|
| +// "passwords":[{"element":"","value":"asd"}]}
|
| +- (void)extractForm:(NSString*)formName
|
| + completionHandler:(void (^)(NSString*))completionHandler;
|
| +
|
| +// Fills in the password form specified by |JSONString| with the given
|
| +// |username| and |password|. Assumes JavaScript has been injected previously
|
| +// by calling |findPasswordFormsWithCompletionHandle| or
|
| +// |extractSubmittedFormWithCompletionHandler|. Calls |completionHandler| with
|
| +// YES if the filling of the password was successful, NO otherwise.
|
| +// |completionHandler| cannot be nil.
|
| +- (void)fillPasswordForm:(NSString*)JSONString
|
| + withUsername:(NSString*)username
|
| + password:(NSString*)password
|
| + completionHandler:(void (^)(BOOL))completionHandler;
|
| +
|
| +// Clears autofilled credentials in the specified form. Invokes
|
| +// |completionHandler| with YES if successful and NO otherwise.
|
| +- (void)clearAutofilledPasswordsInForm:(NSString*)formName
|
| + completionHandler:(void (^)(BOOL))completionHandler;
|
| +
|
| +// Fills all password fields in the form identified by |formName| with
|
| +// |password| and invokes |completionHandler| with true if any fields were
|
| +// filled.
|
| +- (void)fillPasswordForm:(NSString*)formName
|
| + withGeneratedPassword:(NSString*)password
|
| + completionHandler:(void (^)(BOOL))completionHandler;
|
| +
|
| +@end
|
| +
|
| +#endif // IOS_CHROME_BROWSER_PASSWORDS_JS_PASSWORD_MANAGER_H_
|
|
|