a2nt/silverstripe-vkconnect

Integration of VK Connect into SilverStripe

Installs: 9

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 3

Forks: 0

Open Issues: 0

Type:silverstripe-module

dev-master 2017-08-15 18:26 UTC

This package is auto-updated.

Last update: 2024-04-07 12:34:07 UTC


README

Maintainer Contact

Requirements

  • SilverStripe 3.2

Overview

The module provides a basic interface for implementing the Vk PHP SDK on your SilverStripe website. The Vk SDK allows users to login to your website using their Vk account details, creating a single sign-on within the existing SilverStripe member system.

What it provides

  • Loads the VK PHP SDK.

  • Provides $VkLoginLink template variable to generate a link to login to VK.com Upon clicking the link and being redirected back to your application the SilverStripe Member::currentUser() will be populated with a Member instance linked to the users VK profile.

<% with CurrentMember %>
	$Name $Avatar(small)
<% end_with %>

Installation

composer require "a2nt/silverstripe-vkconnect" "dev-master"

Register your website / application with VK.

Set your configuration through the SilverStripe Config API. For example I keep my configuration in mysite/_config/vkconnect.yml file:

VkControllerExtension:
  app_id: 'MyAppID'
  api_secret: 'Secret'

Update the database by running /dev/build to add the additional fields to the Member table and make sure you ?flush=1 when you reload your website.

<a href="$VkLoginLink">Login via Vk</a>

You can also access the Vk PHP SDK in your PHP code..

// https://developers.Vk.com/docs/php/VkSession/4.0.0
$session = Controller::curr()->getVkSession();

For more information about what you can do through the SDK see:

https://vk.com/dev/manuals

Options

All the following values are set either via the Config API like follows

Config::inst()->update('VkControllerExtension', '$option', '$value')

Or (more recommended) through the YAML API

VkControllerExtension: option: value

app_id

Your app id. Found on the Vk Developer Page.

api_secret

Vk API secret. Again, from your Application page.

create_member

Optional, default: true

Whether or not to create a Member record in the database with the users information. If you disable this, ensure your code uses $CurrentVkMember rather than $Member. Other access functionality (such as admin access) will not work.

member_groups

Optional, default ''

A list of group codes to add the user. For instance if you want every member who joins through Vk to be added to a group Vk Members set the following:

VkControllerExtension: member_groups: - Vk_members

permissions

Optional, default 'email'

A list of permission codes you want from the user. Permission codes are listed on developers.Vk.com.

Ensure you include email in your list if you require create_member.

Vk_fields

Default 'email','first_name','last_name'

A list of fields you want to retrieve from Vk for the user. Available fields are listed on developers.Vk.com.

Ensure you include email in your list if you require create_member.

sync_member_details

Optional, default true

Flag as to whether to replace user information (such as name) in your database with the values from Vk.

License

Released under the BSD-3-Clause License.