glance-project / photo-service
Glance project service for managing user photos
Requires
- php: ^8.2
- doctrine/dbal: ^2.13
- guzzlehttp/guzzle: ^6.0 || ^7.0
- php-di/php-di: 7.0
- vlucas/phpdotenv: ^4.1 || ^5.5
- webmozart/assert: 1.11
Requires (Dev)
- phpunit/phpunit: ^11
- squizlabs/php_codesniffer: 3.4.2
This package is auto-updated.
Last update: 2024-12-16 08:28:44 UTC
README
Repository for the common service used by the GLANCE team to manage photo consent.
Usage
Install
Install using composer:
composer-require glance-project/photo-service
Usecases
Get User Consent
Find members who have registered their consent in certain application:
use Glance\PhotoService\UserConsent\Infrastructure\Provider\UserConsentProviderFactory;
$provider = UserConsentProviderFactory::getUserConsentInstance(
"<photo-db-username>",
"<photo-db-password>",
"<photo-db-dns>"
);
$details = $provider->findUserConsentDetailsByApplicationId("<your-application-id>");
Find consent of given member in your application:
use Glance\PhotoService\UserConsent\Infrastructure\Provider\UserConsentProviderFactory;
$provider = UserConsentProviderFactory::getUserConsentInstance(
"<photo-db-username>",
"<photo-db-password>",
"<photo-db-dns>"
);
$details = $provider->findUserConsentDetailsByPersonId(<member-person-id>,"<your-application-id>");
Get User Consent History
To get the consent history based on the person id of the member:
use Glance\PhotoService\UserConsent\Infrastructure\Provider\UserConsentProviderFactory;
$provider = UserConsentProviderFactory::getUserConsentInstance(
"<photo-db-username>",
"<photo-db-password>",
"<photo-db-dns>"
);
$details = $provider->findUserConsentHistoryDetailsByPersonId(<member-person-id>, "<your-application-id>");
To get the consent history based on the application id only:
use Glance\PhotoService\UserConsent\Infrastructure\Provider\UserConsentProviderFactory;
$provider = UserConsentProviderFactory::getUserConsentInstance(
"<photo-db-username>",
"<photo-db-password>",
"<photo-db-dns>"
);
$details = $provider->findUserConsentHistoryDetailsByApplicationId("<your-application-id>");
Update Consent
use Glance\PhotoService\UserConsent\Infrastructure\Provider\UserConsentProviderFactory;
$provider = UserConsentProviderFactory::getUserConsentInstance(
"<photo-db-username>",
"<photo-db-password>",
"<photo-db-dns>"
);
$details = $provider->updateUserConsent(
<member-person-id>,
(bool) <new-consent>,
"<your-application-id>",
<agent-person-id>
);
Get Photo
A UnableToFetchFromAdamsException
is thrown if the ADAMS api is not answering correctly.
A UserHasNotGivenConsent
is thrown if the user has not given consent.
use Glance\PhotoService\Photo\Infrastructure\Provider\PhotoProviderFactory;
$photoProvider = PhotoProviderFactory::getPhotoProvider(
"<service-account-username>",
"<service-account-password>",
"<experiment-api-endpoint>",
"<photo-db-username>",
"<photo-db-password>",
"<photo-db-dns>"
);
$photoProvider->getPhoto(
<person-id>,
"<application-id>"
);
Test environment setup
We rely on .env
files to handle secret values.
Therefore, create a new .env.local
, if it doesn't yet exist, and copy everything from .env
to the local one. The database credentials must be from the photo DB.
# .env.local
DB_USERNAME=<username>
DB_DNS=<dns>
DB_PASSWORD=<password>
Starting the container
In order to start developing, after you've cloned the repository you'll need to start the container for the service. To do that, run the following command:
docker-compose up -d
Once the container is up and running, execute docker exec -it photo-service bash
so you are prompted to the container CLI.
Installing php dependencies
In order to install the php dependencies, run composer install
inside the container so composer will install exactly the specific versions set on the composer.lock
file.