Registering a client with an OAuth 2 server
Before you can delegate certificates using the OA4MP service,
you must register your OA4MP client. In the course of this you will receive
two things:
- a client identifier
- a client secret
The client identifier is a unique string that is used to identify your client to the
server. This should be put into your configuration file. Rather than exchange public keys or
some other method of ensuring that your client is indeed authentic, a client secret
is generated at run time. This is the only time it actually is shown. The server merely
stores a hash of this rather than the actual value, consequently you have the only copy.
If you lose this, you must register your client again.
Filling out the registration form
The default registration form looks like this:
The various fields are as follows:
- Client Name: A human readable name for the science gateway (OA4MP client) that
you are registering. This will be displayed to users and should identify your site.
- Contact email: An email address where a human being can be reached for support.
- Home url: The main address for your site. This will be displayed to users as part of the
authentication process. It is not required to be secure.
- Callback URLs
A list of callback URLs, one per line must be registered
with the server. Client requests must send one of these and if the callback urls sent
does not match one of the registered ones, the
client request will be rejected. At this point, no wildcards are accepted.
As per the specification, all of these must be secure or the request will be rejected.
- Scopes: The scopes that this client would like. Since this is for OIDC, you should always
keep the openid scope checked (though if you do not, it will be added anyway). This list is generated from the
server
(the screen shot is merely an example)
and while you may request any of the scopes, these are subject to approval. Be advised that if the client
later requests an unapproved scope, this will result in an error.
- Refresh token lifetime: (in seconds). This may be present but only if the server actually
supports this feature. If it is available and you leave this blank, then no refresh tokens will be issued for your client.
- Issuer: The specific issuer for this client. Note that this is not trivial to specify
and you should probably read the corresponding server documents on issuers
if you need to.
- Limited proxy support. This is mostly needed by servers that are affiliated with Globus. If
this is present, you should understand what it does before checking it.
Fill in the appropriate values. Note that the contact email should be for an actual person, not a generic
one for an organization since an email will be sent to it once the client has been approved. When you click
submit you should get a page like this
The only warning with the secret is to be sure that when you copy and paste it into the configuration file
that you do not introduce spaces or line breaks. The secret should be a single line. The server administrator
will get a notice that your client has requested approval and once this has been reviewed, an email will be sent
to the contact email you gave above.