I'm new to strapi and in general with back end development and I'm trying to understand how a very small things should work.
I have a User model, a Profile model and a Fare model.
A User can have a Profile so I created a relation has and belongs to one
.
A Profile can have a Fare and I created the same relation between Profile and Fare.
What I noticed here is:
When in the client I land to the profile section I do save it with all it properties like: name, surname, address, etc... and everything is going fine by adding the user id to it.
The point here is that in the same profile section I also have fares inputs and what I would like to do is to save fares by saving the profile and not adding a special save button just for the fares...
Is it something possible to do or am I doing something wrong in here?
I'm separating fares by profile to be able to better find, organise and work with fares without querying for profiles every time but having profile records by id ro something...
Can someone explain clearly the best approach and what should I do to achieve it correctly? Thanks
Relations can be set in Strapi's Collection types, Single types, and Components. The relation is set when adding fields to our Collection, Single collection, or Component type.
Complex populating can be achieved by using the filters parameter and select or populate nested relations or components: const entries = await strapi. entityService. findMany('api::article.
Navigate to your demoapp folder and run npx strapi generate to create a custom API endpoint. Make sure the api option is selected and click enter.
In Strapi, relations are a convenient way to connect different entities with each other. For reference, an entity is an instance of a content-type. So "My first post" is an entity of the Post collection type.
The APIs in Strapi is built in the form of collections or single types. A collection in Strapi will create and expose the endpoints on all the HTTP verbs. For example, if we have a blog collection.
That way, you should be able to retrieve the user info you need. Now, you can simply call the callback function with the username and email of your user. That way, Strapi will be able to retrieve your user from the database and log you in. Now, we need to configure our 'model' for our new provider.
Configure the new provider in the Provider.js file at the getProfile function. The getProfile takes three params: provider: The name of the used provider as a string. query: The query is the result of the provider callback. callback: The callback function who will continue the internal Strapi login logic.
Form
HTML input to create nested json data you can build a form and test the output
<form action="profiles" method="POST" accept-charset="utf-8">
<input type="text" name="name" value="MyProfileName" />
<input type="text" name="fare[name]" value="MyProfileFareName" />
</form>
parameters
Parameters will be received from your backend as
name=MyProfileName&fare[name]=MyProfileFareName
The controller will parse the above parameters as json
{
'profile' => {
'name' => 'MyProfileName',
'fare' => {
'name' => 'MyProfileFareName',
}
}
}
create
or update
actionController should be responsible to use the parameters received and update the Database Models. The add
and edit
methods to persist the model
in the database
are defined inside the service
s objects (not inside the controller), the controller responsibility is solely to call those methods.
You can retrieve the parameters
from the body
of the request
. The request
object is available inside the controller ctx.request
As in this example the create
action uses the .add
method from the category
services class. The api docs have no explanation about this and you should follow the example on github.
module.exports = {
// POST /profiles
create: async (ctx) => {
// use the fare service to add a new entry with value request.body.fare
var profile = strapi.services.profile.add(ctx.request.body)
strapi.services.fare.add(ctx.request.body.fare)
return profile
}
};
Profile
service add
and edit
methodsyou can review the examples on github to better understand the logic of the add
and edit
methods.
add: async (values) => {
// Extract values related to relational data.
const relations = _.pick(values, Profile.associations.map(ast => ast.alias));
const data = _.omit(values, Profile.associations.map(ast => ast.alias));
// Create entry with no-relational data.
const entry = await Profile.create(data);
// Create relational data and return the entry.
return Profile.updateRelations({ _id: entry.id, values: relations });
},
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With